zoukankan      html  css  js  c++  java
  • ipsec报文格式

    IPSec报文格式

    IPSec协议族是IETF(Internet Engineering Task Force)制定的一系列协议,它为IP数据报提供了高质量的、可互操作的、基于密码学的安全性。

    IPSec通过认证头AH(Authentication Header,协议号51)和封装安全载荷ESP(Encapsulating Security Payload)这两个安全协议来实现。AH可提供数据源验证和数据完整性校验功能;ESP除可提供数据验证和完整性校验功能外,还提供对IP报文的加密功能。

    IPSec协议有两种封装模式:

    • 传输模式。在传输模式下,AH或ESP被插入到IP头之后但在所有传输层协议之前,或所有其他IPSec协议之前。

    • 隧道模式。在隧道模式下,AH或ESP插在原始IP头之前,另外生成一个新IP头放到AH或ESP之前。

    传输模式用于两台主机之间的通讯,或者是一台主机和一个安全网关之间的通讯。在传输模式下,对报文进行加密和解密的两台设备本身必须是报文的原始发送者和最终接收者。

    通常,在两个安全网关(路由器)之间的数据流量,绝大部分都不是安全网关本身的通讯量,因此在安全网关之间一般不使用传输模式,而总是使用隧道模式。在一个安全网关被加密的报文,只有另一个安全网关能够解密。因此必须对IP报文进行隧道封装,即增加一个新的IP头,进行隧道封装后的IP报文被发送到另一个安全网关,才能够被解密。

    报文格式

    图1 AH封装及头部格式
    字段长度描述
    Next Header 8比特 表示认证头部之后的下一个负载。
    Payload Len 8比特 AH的长度减2,4字节为计数单位。例如,有个96比特的认证值,长度将是"4"(即头部固定的3个4字节 + ICV的3个4字节 - 2)。对于IPv6,头部总长度必须为8字节的倍数。
    RESERVED 16比特 预留将来使用。必须置0,接收时忽略。
    Security Parameters Index 32比特 用于给报文接收端识别SA
    Sequence Number Field 32比特 序列号,每发送一个报文,计数加1,例如每发一个SA报文序列号增加1。
    Integrity Check Value-ICV 变长 报文的ICV字段,可变长度,长度必须为32比特的整数倍。
    图2 ESP封装及头部格式
    字段长度描述
    Security Parameters Index 32比特 安全参数索引。
    Sequence Number 32比特 序列号。
    Payload Data* 变长 有效载荷数据(可变)。
    Padding 0–255字节 填充字段。
    Pad Length 8比特 填充字段长度。
    Next Header 8比特 下一个头。
    Integrity Check Value-ICV 变长 验证数据。
    图3 AH和ESP协议组合使用

    因特网密钥交换协议IKE(Internet Key Exchange)是IPSEC的信令协议。

    图4 IKE Header Format

    字段长度描述
    IKE_AS Initiator's SPI 8 bytes 发送者用来唯一标识一个IKE安全联盟,该值不能设置为0。
    IKE_AS Responder's SPI 8 bytes 应答者用来唯一标识一个IKE安全联盟,对于IKE初始交互的消息该值必须为0,其他消息不能为0。
    Next Payload 1 byte 仅随头部之后的负载的类型。
    MjVer 4 bits 标识所使用的IKE协议的最大版本。
    MnVer 4 bits 标识所使用的IKE协议的最小版本。
    Exchange Type 1 byte
    • 0-33: RESERVED
    • 34: IKE_SA_INIT
    • 35: IKE_AUTH
    • 36: CREATE_CHILD_SA
    • 37: INFORMATIONAL
    • 38-239: RESERVED TO IANA
    • 240-255: Reserved for private use.
    Flags 1 byte 消息中设置的特定选项。如果Flag域置位表示带有选项。
    • X(reserved) (bits 0-2) - 发送时必须清0,接收时忽略。
    • I(nitiator) (bit 3 of Flags) - IKE_SA原始发送者在发送消息是必须将此位置1,源回应者发送的消息必须清零。
    • V(ersion) (bit 4 of Flags) - 标识转发者支持的版本比Major字段标识的版本更高 IKEv2版本的实现中,此比特必须置0,接收时忽略。
    • R(esponse) (bit 5 of Flags) - 标识此消息是对相同Message-ID的消息的一个回应消息。所有请求消息中此位需置0,所有回应消息置1。
    • X(reserved) (bits 6-7 of Flags) - 发送时需置0,接收时忽略。
    Message ID 4 bytes 消息标识符,用来对请求消息和呼应消息的匹配,以便控制丢弃消息的重复发送。这在抑制重放攻击时对保障协议的安全性很关键。
    Length 4 bytes 整个消息的长度(报文头+负荷),以字节为单位。
    Next Payload 1 byte 标识消息中的下一个负载的类型。如果当前的负载是消息的最后一个,则此字段置0。
    • 0: No Next Payload
    • 1-32: RESERVED
    • 33: Security Association (SA)
    • 34: Key Exchange (KE)
    • 35: Identification - Initiator (IDi)
    • 36: Identification - Responder (IDr)
    • 37: Certificate (CERT)
    • 38: Certificate Request (CERTREQ)
    • 39: Authentication (AUTH)
    • 40: Nonce (Ni, Nr)
    • 41: Notify (N)
    • 42: Delete (D)
    • 43: Vendor ID (V)
    • 44: Traffic Selector - Initiator (TSi)
    • 45: Traffic Selector - Responder (TSr)
    • 46: Encrypted (E)
    • 47: Configuration (CP)
    • 48: Extensible Authentication (EAP)
    • 49-127: RESERVED TO IANA
    • 128-255: PRIVATE USE
    C (Critical) 1 bit
    • 如果发送者想让接收者在无法识别当前一个负载的Next Payload域是能够跳过此域,可将此位置0。
    • 如果接收者能够识别负载的类型代码,则忽略此位。
    • 负载类型为以下情况时,此位必须设置为0。
      • Security Association (SA)
      • Key Exchange (KE)
      • Identification - Initiator (IDi)
      • Identification - Responder (IDr)
      • Certificate (CERT)
      • Certificate Request (CERTREQ)
      • Authentication (AUTH)
      • Nonce (Ni, Nr)
      • Notify (N)
      • Delete (D)
      • Vendor ID (V)
      • Traffic Selector - Initiator (TSi)
      • Traffic Selector - Responder (TSr)
      • Encrypted (E)
      • Configuration (CP)
      • Extensible Authentication (EAP)

    注意,C比特应用于当前负载,而不是下一个负载。

    RESERVED 7 bits 发送时必须置0,接收时忽略。
    Payload Length 2 bytes 当前负载的长度,包括通用负载的头部,以字节为单位。

    参考标准

    标准描述
    RFC 4302 IP Authentication Header
    RFC 4303 IP Encapsulating Security Payload (ESP)
    RFC 4306 Internet Key Exchange (IKEv2) Protocol
     
  • 相关阅读:
    解析库的使用---页面解析总结
    django--学习笔记 一
    项目(三)--个人博客开发
    算法图解(python3版本)--读后感
    "mysql技术内幕innodb存储引擎"--读书笔记
    通过ftp同步服务器文件:遍历文件夹所有文件(含子文件夹、进度条);简单http同步服务器文件实例
    使用node-webkit(v0.35.5)和innosetup(3.6.1)打包将web程序打包为桌面客户端(安装包)
    .netcore3.1使用ELK日志中心(使用NLog数据传输)
    .netcore3.1使用skywalking8.1.0(docker-compose一键部署)
    asp.net 页面刷新锚点失效问题解决
  • 原文地址:https://www.cnblogs.com/zafu/p/15588884.html
Copyright © 2011-2022 走看看