1.IP层的安全:IPSec
IP层安全(IP security,IPsec)是由因特网工程任务组(IETF)设计用来为IP层的分组提供安全的一组协议。IPsec帮助
生成经过鉴别的与安全的IP层的分组,如下图:
1.1.两种方式
在传输方式(transport mode)下,IPsec保护传输层到网络层传递的内容,换言之,传输方式保护网路层的有效载荷,在网络层
中封装有效载荷。
传输方式通常用于主机到主机的数据保护,发送主机使用IPsec鉴别和/或加密来自传输层的有效载荷。接受主机使用IPSec检验鉴别1.2.两种安全协议
1.2.1.鉴别头部协议
当由IP数据报携带鉴别头部时,IP头部中协议字段的初始值就替换为值51。在鉴别头部内的一个字段(写一个头部字段)规定了协
议字段的初始值(由IP数据报携带的有效载荷类型)。加入鉴别头部的步骤如下:
a. 鉴别头部加入到有效载荷中,将鉴别数据字段的值置为0.
b. 散列处理是根据总的分组计算的。但是,IP头部中只有在传输过程中不发生改变的那些字段才包含在报文摘要(鉴别数据)的
计算过程中。
c. 将鉴别数据加入到鉴别头部中协议字段的值改为51,将IP头部加入。
1.2.2.封装安全载荷
当IP数据报携带ESP的头部和尾部时,IP头部中协议字段的值更改为50。在ESP尾部内有一个字段(下一个头部字段)保留着协议字段的初始值
(IP数据报所携带的载荷类型,比如TCP或UDP)。ESP过程遵循下列步骤:
a. 对ESP尾部加入到有效载荷中。
b. 对有效载荷和尾部进行加密。
c. 加入ESP头部。
d. 使用ESP头部,有效载荷以及ESP尾部生成鉴别数据。
e. 将鉴别数据加入到ESP尾部的末尾。
f. 将协议值改为50后,在加入到IP头部。
1.2.3.AH和ESP
1.2.4.IPSec提供的服务
AH和ESP两个协议可在网路层对分组提供几种安全服务。
访问控制:IPSec通过安全关联数据库(SADB)简介地提供访问控制,当一个分组到达目的端时,如果还没有为该分组建立安全关联,那么就
丢弃该分组。
报文鉴别:AH和ESP两者通过使用鉴别数据提供报文的完整性。生成一个数据摘要,该摘要由发送方发给接收方,由接收方进行检验。
实体鉴别:在AH和ESP中,用发送方发送的安全关联和秘钥散列数据摘要鉴别数据的发送方。
保密性:在ESP中报文加密提供保密性,但是AH没有提供保密性。如果需要保密性,我们应该用ESP而不是AH。
避免重放攻击:在两个协议中,用序列号和一个滑动窗口防止重放攻击(reply attack)。当建立安全关联时,每个IPSec头部都有一个1.3.安全关联
1.4.因特网密钥交换(IKE)
现在我们来解决最后的部分,如何创建SADB。因特网密钥交换(Internet key exchange,IKE)是用于建立SADB中入关联于
出关联的一个协议。
IKE是在其他三个协议(Oakley,SKEME和ISAKMP)之上的一个更复杂的协议。如下图所示:Oakley协议时由Hilarieorman开发的一个协议,他是在Diffie-Hellman密钥交换方法基础上的一个密钥生成协议,但做了一些改进,
Oakley是一个无格式的协议,就是说没有规定交换的报文格式。
SKEME是有HugoKrawcyzk设计的,它是另一个密钥交换协议,它使用公钥密码和密钥交换作为实体鉴别。
因特网安全关联和密钥管理协议(Internet SecurityAssociation and Key Management Protocol, ISAKMP)是由国家安全机构(NSA)
设计的协议,它具有实现IKE定义的交换。在生成标准化的和格式化的保温过程中,它允许IKE交换的多个分组,协议以及参数,从而生成安
全关联。