PPP详解

首先看看”SLIP“协议。改协议可以理解为PPP的一个简化版本,对于加深对PPP协议的理解有些帮助。
   此外,通过观察“SLIP”协议的一些不足,可以让我们更加深入的理解PPP协议的设计的巧妙和针对性
PPP详解_第1张图片
SLIP简单封装方式的缺陷:

  • 因为没有一个协商的过程,所以很多参数(比如ip地址)就需要实现直到

  • 没有一个域来指定上层协议,所以这里肯定只能使用一种协议,而且因为没有实现协商的机制,所以动态的决定无法实现

  • 没有校验和,某些错误无法及时发现。而需要等到上层协议来处理。浪费系统资源 

    注意ppp和我们常用的以太网没什么必然的联系。都属于数据链路层。
    PPP详解_第2张图片

    地址域(Add),数据帧(Ctrl的控制域也没有实际意义
    考虑到ppp协议是点对点协议,所以ppp协议无需以太网哪种mac地址。
    协议域标示包装数据包内数据的协议
    PPP详解_第3张图片






    ip协议就不说拉,重点讲下上面四种协议
    LCP协议


    PPP详解_第4张图片
    代码域:标示”子协议“
    PPP详解_第5张图片
    标识域:相当于报文ID。
    长度域:长度域内容 = 总字节数据(代码域+标志域+长度域+数据域)。长度域所指示字节数之外的字节将被当作填充字节而忽略掉


    LCP数据报文的分类
    1.链路配置报文
    ,主要用来建立和配置一条链路的。包括Config-Request 、Config-Ack 、Config-Nak 和Config-Reject

    PPP详解_第6张图片

    其中类型域包含
    PPP详解_第7张图片

    配置过程中的一些协商问题

  • 当接收Config-Request报文的一端能识别发送过来的所有配置参数选项且认可所有配置参数选项数据域的内容时,接收端将会给对端回一个Config-Ack报文并将配置请求报文中的配置参数选项原封不动的放置在
    Config-Ack报文的数据域内(根据协议的规定是不可改变配置参数选项的顺序)。当配置请求报文的发送端收到Config-Ack报后,则会从当前阶段进入到下一个阶段。

    当接收Config-Request报文的一端能识别发送端所发送过来的所有配置参数选项,但对部分配置参数选项数据域中的内容不认可时,接收端将会给对端回应一个Config-Nak报文,该报文中只携带不认可的配置参数选
    项,而这些配置参数选项的数据内容为本端希望的值。然而当接收端收到Config-Nak 报文后, 会重新发送Config-Request 报文, 而这个Config-Request报文与上一次所发送的Config-Request报文区别在于那些被对端不认可的配置参数选项的内容被填写到刚刚协商完后再次发送的Config-Request报文中(Config-Nak报文发送回来的那些配置参数选项)。

    当接收Config-Request报文的一端不能识别所有的发送端发送过来的配置参数选项时,此时接收端将会向对端回一个Config-Reject报文,该报文中的数据域只携带那些不能识别的配置参数选项(当配置参数选项的类
    型域不识别时)。当对端接收到Config-Reject报文后,同样会再次发送一个Config-Request报文,这个配置请求报文与上一次发送的区别在于将不可识别的那些配置参数选项给删除了。

    链路终止报文,主要用来终止一条链路的。包括Terminate-Request和Terminate-Reply
    链路维护报文,主要用来维护和调试链路的。除上述两种报文类型以外,剩余的所有报文类型均归属链路维护报
    维护报文的产生

  • 当接收端发现LCP报文的代码域是一个不合法的值时,将会向发送端回应一个Code-Reject报文,在回应报文中会将所拒绝报文的内容附加上。

    当接收端发现所接收到的数据帧的协议域是一个不合法的值时,将会向发送端回应一个Protocol-Reject报文,发送端收到该拒绝报文后将停止发送该种协议类型的数据报文了。Protocol-Reject报文只能在LCP的状态机处于Opened状态时才可被处理,而在其它状态接收到该报文将被丢弃。在Protocol-Reject报文的数据域内将携带所拒绝报文的协议类型和报文内容。

    Echo-Request报文和Echo-Reply报文主要用来检测双向链路上自环的问题,除此之外还可附带做一些链路质量的测试和其它功能。当LCP状态机处于Opened状态时,如果接收到了Echo-Request,就需向对端回送一个Echo-Reply报文。否则在其它LCP状态下,该类型的报文会被丢弃。这种类型数据报文的长度域后不是直接跟数据域,而是要插入4个字节的Magic-Number(魔术字),该魔术字是在LCP的Config-Request的配置参数选项协商时获得的。

    NCP协议
    NCP协议主要包括IPCP、IPXCP等,但我们在实际当中最常遇见的也只有IPCP协议了
    注意:NCP不是一个具体的协议,而是比如IPCP,IPXCP等协议的一个统称。


    IPCP
    IPCP控制协议主要是负责完成IP网络层协议通信所需配置参数的选项协商的。IPCP在运行的过程当中,主要是完成点对点通信设备的两端动态的协商IP地址。

    协议报文和lcp类似。包类型是lcp的一个子集,常用的如Config-Request、Config-Ack、Config-Nak和Config-Reject

    静态协商,也即是不协商。点对点的通信设备两端在PPP协商之前已配置好了IP地址,所以就无须在网络层协议阶段协商IP地址,而双方唯一要做的就是告诉对方自身的IP地址。
    PPP详解_第8张图片
    双方分别将自己的ip和其他可选的信息告诉对方


    动态协商,也即是一端配置为动态获取IP地址,另一端通过手动方式配置IP地址,且允许给对端分配IP地址,这个过程实际上可与窄带拨号上网的过程相一致
    PPP详解_第9张图片
    sender首先将ip域置于0,以向receiver动态一个ip地址。后面四个和静态协商一致。


    认证协议
    PPP协议也提供了可选的认证配置参数选项,缺省情况下点对点通信的两端是不进行认证的。在LCP的Config-Request报文中不可一次携带多种认证配置选项,必须二者择其一(PAP/CHAP)

    注意认证过程在lcp和ncp中间进行

    PAP
    PPP详解_第10张图片
    PAP认证是两次握手(单方向)。
    用户名和密码使用明文,安全性较差


    CHAP

    PPP详解_第11张图片
         开始由验证方向被验证方发送一段随机的报文,并加上自己的主机名。当被验证方收到验证方的验证请求,从中提取出验证方所发送过来的主机名,然后根据该主机名在被验证方设备的后台数据库中去查找相同的用户名的记录,当查找到后就使用该用户名所对应的密钥,然后根据这个密钥、报文ID和验证方发送的随机报文用Md5加密算法生成应答,随后将应答和自己的主机名送回,同样验证方收到被验证方发送回应后,提取被验证方的用户名,然后去查找本方一致用户名后,根据该用户名所对应的密钥、保留报文ID和随机报文用Md5加密算法生成结果,和刚刚被验证方所返回的应答进行比较,相同则返回Ack,否则返回Nak
  • 你可能感兴趣的:(算法,数据库,加密,网络,测试)