PPP协议组成及简述协议协商的基本过程


Posted in 面试题 onMay 28, 2015
一、PPP(Point-to-Point Protocol点到点协议)是为在同等单元之间传输数据包这样的简单链路设计的链路层协议。设计目的主要是用来通过拨号或专线方式建立点对点连接发送数据,使其成为各种主机、网桥和路由器之间简单连接的一种共通的解决方案。
二、PPP协议中提供了一整套方案来解决链路建立、维护、拆除、上层协议协商、认证等问题。
三、PPP协议包含这样几个部分:链路控制协议LCP(Link Control Protocol);网络控制协议NCP(Network Control Protocol);认证协议,最常用的包括口令验证协议PAP(Password Authentication Protocol)和挑战握手验证协议CHAP(Challenge-Handshake Authentication Protocol)。
四、一个典型的链路建立过程分为三个阶段:创建阶段、认证阶段和网络协商阶段。
阶段1:创建PPP链路
LCP负责创建链路。在这个阶段,将对基本的通讯方式进行选择。链路两端设备通过LCP向对方发送配置信息报文(Configure Packets)。一旦一个配置成功信息包(Configure-Ack packet)被发送且被接收,就完成了交换,进入了LCP开启状态。
应当注意,在链路创建阶段,只是对验证协议进行选择,用户验证将在第2阶段实现。
阶段2:用户验证
在这个阶段,客户端会将自己的身份发送给远端的接入服务器。该阶段使用一种安全验证方式避免第三方窃取数据或冒充远程客户接管与客户端的连接。在认证完成之前,禁止从认证阶段前进到网络层协议阶段。如果认证失败,认证者应该跃迁到链路终止阶段。
在这一阶段里,只有链路控制协议、认证协议,和链路质量监视协议的packets是被允许的。在该阶段里接收到的其他的packets必须被静静的丢弃。
最常用的认证协议有口令验证协议(PAP)和挑战握手验证协议(CHAP)。 认证方式介绍在第三部分中介绍。
阶段3:调用网络层协议
认证阶段完成之后,PPP将调用在链路创建阶段(阶段1)选定的各种网络控制协议(NCP)。选定的NCP解决PPP链路之上的高层协议问题,例如,在该阶段IP控制协议(IPCP)可以向拨入用户分配动态地址。
这样,经过三个阶段以后,一条完整的PPP链路就建立起来了。
五、认证方式
1)口令验证协议(PAP)
PAP是一种简单的明文验证方式。NAS(网络接入服务器,Network Access Server)要求用户提供用户名和口令,PAP以明文方式返回用户信息。很明显,这种验证方式的安全性较差,第三方可以很容易的获取被传送的用户名和口令,并利用这些信息与NAS建立连接获取NAS提供的所有资源。所以,一旦用户密码被第三方窃取,PAP无法提供避免受到第三方攻击的保障措施。
2)挑战-握手验证协议(CHAP)
CHAP是一种加密的验证方式,能够避免建立连接时传送用户的真实密码。NAS向远程用户发送一个挑战口令(challenge),其中包括会话ID 和一个任意生成的挑战字串(arbitrary challengestring)。远程客户必须使用MD5单向哈希算法(one-way hashing algorithm)返回用户名和加密的挑战口令,会话ID以及用户口令,其中用户名以非哈希方式发送。
CHAP对PAP进行了改进,不再直接通过链路发送明文口令,而是使用挑战口令以哈希算法对口令进行加密。因为服务器端存有客户的明文口令,所以服务器可以重复客户端进行的操作,并将结果与用户返回的口令进行对照。CHAP为每一次验证任意生成一个挑战字串来防止受到再现攻击(replay attack)。在整个连接过程中,CHAP将不定时的向客户端重复发送挑战口令,从而避免第3方冒充远程客户(remote client impersonation)进行攻击。
六、PPP协议的应用
PPP协议是目前广域网上应用最广泛的协议之一,它的优点在于简单、具备用户验证能力、可以解决IP分配等。
家庭拨号上网就是通过PPP在用户端和运营商的接入服务器之间建立通信链路。目前,宽带接入正在成为取代拨号上网的趋势,在宽带接入技术日新月异的今天,PPP也衍生出新的应用。典型的应用是在ADSL(非对称数据用户环线,Asymmetrical Digital Subscriber Loop)接入方式当中,PPP与其他的协议共同派生出了符合宽带接入要求的新的协议,如PPPoE(PPP over Ethernet),PPPoA(PPP over ATM)。
利用以太网(Ethernet)资源,在以太网上运行PPP来进行用户认证接入的方式称为PPPoE。PPPoE即保护了用户方的以太网资源,又完成了ADSL的接入要求,是目前ADSL接入方式中应用最广泛的技术标准。
同样,在ATM(异步传输模式,Asynchronous Transfer Mode)网络上运行PPP协议来管理用户认证的方式称为PPPoA。它与PPPoE的原理相同,作用相同;不同的是它是在ATM网络上,而PPPoE是在以太网网络上运行,所以要分别适应ATM标准和以太网标准。
PPP协议的简单完整使它得到了广泛的应用,相信在未来的网络技术发展中,它还可以发挥更大的作用

Tags in this post...

面试题 相关文章推荐
数据库连接池的工作原理
Sep 26 面试题
C语言中一个结构不能包含指向自己的指针吗
May 25 面试题
编写用C语言实现的求n阶阶乘问题的递归算法
Oct 21 面试题
枚举和一组预处理的#define有什么不同
Sep 21 面试题
实现向右循环移位
Jul 31 面试题
某公司.Net方向面试题
Apr 24 面试题
程序集与命名空间有什么不同
Jul 25 面试题
介绍一下HTTP、HTTPS和SSL
Dec 16 面试题
TCP/IP的分层模型
Oct 27 面试题
在子网210.27.48.21/30种有多少个可用地址?分别是什么?
Jul 27 面试题
What's the difference between an interface and abstract class? (接口与抽象类有什么区别)
Oct 29 面试题
init进程的作用
Apr 12 面试题
网络通讯中,端口有什么含义,端口的取值范围
Nov 23 #面试题
什么是URL
Dec 13 #面试题
HSRP的含义以及如何工作
Sep 10 #面试题
Internet主要有哪些网络群组成
Dec 24 #面试题
你对IPv6了解程度
Feb 09 #面试题
STP的判定过程
Oct 01 #面试题
以思科路由器为例你写下单臂路由的配置命令
Aug 03 #面试题
You might like
PHP常见数组排序方法小结
2018/08/20 PHP
laravel 框架配置404等异常页面
2019/01/07 PHP
JavaScript让IE浏览器event对象符合W3C DOM标准
2009/11/24 Javascript
js查错流程归纳
2012/05/04 Javascript
js实现上传图片预览的方法
2015/02/09 Javascript
JS给Textarea文本框添加行号的方法
2015/08/20 Javascript
不能不知道的10个angularjs英文学习网站
2016/03/23 Javascript
vue.js指令v-for使用及索引获取
2016/11/03 Javascript
Bootstrap复选框和单选按钮美化插件(推荐)
2016/11/23 Javascript
浅谈React Event实现原理
2018/09/20 Javascript
浅谈JavaScript 代码简洁之道
2019/01/09 Javascript
详解Vue前端对axios的封装和使用
2019/04/01 Javascript
js实现选项卡效果
2020/03/07 Javascript
微信小程序抽奖组件的使用步骤
2021/01/11 Javascript
[59:26]DOTA2上海特级锦标赛D组资格赛#1 EG VS VP第二局
2016/02/28 DOTA
剖析Django中模版标签的解析与参数传递
2015/07/21 Python
利用Python的Django框架生成PDF文件的教程
2015/07/22 Python
深入理解python对json的操作总结
2017/01/05 Python
Python编程二分法实现冒泡算法+快速排序代码示例
2018/01/15 Python
Python编程argparse入门浅析
2018/02/07 Python
Python输入二维数组方法
2018/04/13 Python
pygame游戏之旅 按钮上添加文字的方法
2018/11/21 Python
numpy按列连接两个维数不同的数组方式
2019/12/06 Python
python 读取更新中的log 或其它文本方式
2019/12/24 Python
python numpy数组复制使用实例解析
2020/01/10 Python
Java里面StringBuilder和StringBuffer有什么区别
2016/06/06 面试题
会计专业毕业生自我鉴定
2013/10/29 职场文书
银行个人求职自荐信范文
2013/12/16 职场文书
技校毕业生自荐信范文
2014/03/07 职场文书
社区党务公开实施方案
2014/03/18 职场文书
2014民事授权委托书范本
2014/09/29 职场文书
学生检讨书
2015/01/27 职场文书
毕业设计答辩开场白
2015/05/29 职场文书
运动会通讯稿600字
2015/07/20 职场文书
MySQL 常见存储引擎的优劣
2021/06/02 MySQL
nginx rewrite功能使用场景分析
2022/05/30 Servers