out_sa()函数报文封装思想讲解

1. out_sa前言

我已经在上一篇文章中将in_struct函数的基本原理进行了阐述,而out_struct()的实现基本是相同的,如果能理解in_struct()函数,那么自己再去看out_structout_rawout_generic等几个函数接口,就不应该是什么问题了。in_struct是将网络字节序结构体转换为主机字节序结构体;out_struct为将主机字节序结构体转换为网络字节序结构体。

这里附上上一篇in_struct的讲解文章:openswan中的in_struct和out_struct函数

我们在看ISAKMP报文封装时,又看到另外一个函数:out_sa()。顾名思义,它是将主机字节序的SA结构转换为网络字节序的SA结构:从抓到的ISAKMP第一个报文可看出**out_sa()就是封装了SA载荷**。这里主要介绍下out_sa()的封装原理和思想,并不是专门来介绍out_sa()功能的。

2. out_sa原理

可能大家都注意到了,openswan中报文封装的格式不同于常见的网络协议栈的封装:

  • 网络协议栈:倒序封装,顺序解封装

这种方式主要的原因还是在于网络分层的缘故。

  • openswan封装/解封装方式:顺序序封装,顺序解封装

它采取这样的处理方式是因为这部分就是应用层的数据,没有必要采用类似网络协议栈的处理方式。但是需要注意的是报文中有长度字段,在没有确定数据部分长度的情况下无法得知长度字段的数据,因此长度字段是延迟到数据部分填充完毕后最后填充的。这是正规的做法,只有完全确定了数据部分长度,才能填充长度字段。我们之所以把ISAKMP的封装和TCPIP协议栈的封装联系在一起,就是因为他们有相同的格式:头部1+头部2+头部3+数据,但是他们封装却大相径庭。就是因为TCPIP协议栈是分层的,而ISAKMP是个应用层数据,没有必要采取那种方式。

刚才说明了ISAKMP中长度字段是最后填充的(这也是比较合理的),这个在out_sa()中体现的更加明显:

实际上out_sa()就是连续多次使用out_struct相关函数实现的;除此之外,还需要填充各个头部的相关字段(SA头部、建议载荷头部、变换载荷头部、变换载荷等),当某一个载荷填充完毕后,调用close_output_pbs()来填充当前载荷的长度字段。

按上图所示,进行简单的介绍:

下面只是填充载荷头部中的长度字段,其他字段的填充是顺序填充的;最后倒序填充长度字段。

2.1 填充变换载荷长度

在填充完毕变换载荷tans_pbs的其他字段(除了长度字段)以及载荷数据部分后,调用close_out_pbs来填充trans_pbs中的长度字段。

2.2 填充建议载荷长度

此时已经填充完毕变换载荷trans_pbs,也就是说建议载荷proposal_pbs的数据部分已经填充完毕,数据长度已经确定下来。因此调用close_output_pbs来填充建议载荷proposal_pbs的长度字段。

2.3 填充SA载荷长度

在所有的建议载荷填充完毕后,需要填充SA载荷sa_pbs中的长度字段,此时调用close_output_pbs()来填充。


2.4 填充ISAKMP载荷长度

这个部分功能已经不再out_sa()函数中实现了,而是在调用out_sa()的函数中实现。不过这没有关系,原理是完全一样的。依然是等确定完毕数据部分长度后最后填充长度字段。由于ISAKMP还需要填充除SA之外的其他载荷部分,例如VID载荷等,因此等这部分填充完毕后再调用close_output_pbs()来填充长度字段。

3. out_sa另一个功能

如果一个pb_stream变量已经调用过一次out_sa, 那么在调用close_output_pbs函数之前不能再次通过out_sa类函数填充载荷。因此out_sa中将该变量的cur指针指向roof,因此无法再次填充数据。当然调用close_output_pbs后就可以再次使用了,此时cur指针已经指向真实的数据末尾,也就是说载荷的长度是在这里确定出来的。

openswan中out_sa()函数报文封装思想的更多相关文章

  1. jquery中ajax中post方法(多学习:洞悉原理,触类旁通)(函数封装思想)

    jquery中ajax中post方法(多学习:洞悉原理,触类旁通)(函数封装思想) 一.总结 1.多看学习视频:洞悉原理,触类旁通, 2.函数封装:$.post(URL,data,callback); ...

  2. java基础课程笔记 static 主函数 静态工具类 classpath java文档注释 静态代码块 对象初始化过程 设计模式 继承 子父类中的函数 继承中的构造函数 对象转型 多态 封装 抽象类 final 接口 包 jar包

    Static那些事儿 Static关键字 被static修饰的变量成为静态变量(类变量) 作用:是一个修饰符,用于修饰成员(成员变量,成员方法) 1.被static修饰后的成员变量只有一份 2.当成员 ...

  3. openswan中的in_struct和out_struct函数

    openswan中的in_struct和out_struct函数 文章目录 openswan中的in_struct和out_struct函数 1. 花絮 2. in_struct代码实现分析 3. 它 ...

  4. JS —— 轮播图中的缓动函数的封装

    轮播图的根本其实就是缓动函数的封装,如果说轮播图是一辆跑动的汽车,那么缓动函数就是它的发动机,今天本文章就带大家由简入繁,封装属于自己的缓动函数~~ 我们从需求的角度开始,首先给出一个简单需求: 1. ...

  5. rxjs入门3之项目中ajax函数封装

    项目中ajax函数封装 ⽹页应⽤主要数据源有两个:⼀个是⽹页中的DOM事件,另⼀个就是通过AJAX获得的服务器资源.我们已经知道fromEvent这个操作符可以根据DOM事件产⽣Observable对 ...

  6. openswan中ISAKMP交互过程关键函数接口

    1. ISAKMP交互过程中关键函数接口 下面分别说明不同的阶段和模式下的函数接口以及对应的报文. 2. 第一阶段(Phase I)主模式函数接口 发送端 响应端 main_outI1 主模式第一包 ...

  7. C++中回调函数(CallBack)的使用

    如果试图直接使用C++的成员函数作为回调函数将发生错误,甚至编译就不能通过. 其错误是普通的C++成员函数都隐含了一个传递函数作为参数,亦即“this”指针,C++通过传递this指针给其成员函数从而 ...

  8. c语言里用结构体和指针函数实现面向对象思想

    一.基础研究 观察如下两个程序a.c和b.c: A.c: B.c: 这两个程序都是要实现在屏幕上第10行40列打印一个绿色的字符c: 这两个程序的数据组织方式是一样的,都是使用结构体,而且对共性和个性 ...

  9. 第四节:详细讲解Java中的类和面向对象思想

    前言 大家好,给大家带来详细讲解Java中的类和面向对象思想的概述,希望你们喜欢 类和面向对象 在Java中怎样理解对象,创建对象和引用:什么是引用,对于基础学习的同学,要深入了解引用.示例:Stri ...

随机推荐

  1. Java的三种日期工具 Date Calendar SimpleDateFormat

    三种日期工具 配合下面的案例可以更加深度的了解 Date 需要导包java.util.Date Date d = new Date(); //两种都是获取到现在时间的时间戳 long t1 = d.g ...

  2. 某学院m3u8视频解密获取分析实战分享

    [免责声明]本文来源于作者个人学习整理,仅供学习交流使用,不构成商业目的.所有资源均系本人个人学习或网络收集,仅提供一个展示.介绍.观摩学习的博文,不对其内容的准确性.可靠性.正当性.安全性.合法性等 ...

  3. 开机时自动启动的AutoHotkey脚本 2019年07月08日19时06分

    ;;; 开机时自动启动的AutoHotkey脚本;; 此脚本修改时间 2019年06月18日20时48分;; 计时器创建代码段 ------------------------------------ ...

  4. 浏览器中hook对象属性

    先获取window对象属性 来源: 夜幕爬虫安全论坛 原文链接: http://bbs.nightteam.cn/thread-485.htm?orderby=desc&user=7

  5. Centos忘记密码怎么修改

    使用Centos系统忘记密码 在我们日常使用Centos系统时,有些人不免会出现一个共同的问题:忘记登录密码! 我们总不能再重装一遍吧! 接下来我们就分两种情况来看看: Centos系统在云服务器 C ...

  6. Windows根据端口号查找对应的进程和服务

    需求 1,我们在Win10安装一些Web服务时,会发现默认端口被占用,比如443端口被占用,808端口被占用,那么如何找出占用这些默认端口的进程和对应的服务呢? 2,系统安装完成后,会有一些应用对外开 ...

  7. [数据结构]ODT(珂朵莉树)实现及其应用,带图

    [数据结构]ODT(珂朵莉树)实现及其应用,带图 本文只发布于博客园,其他地方若出现本文均是盗版 算法引入 需要一种这样的数据结构,需要支持区间的修改,区间不同值的分别操作. 一般的,我们会想到用线段 ...

  8. 【笔记】KNN之分类准确度

    分类准确度 分类准确度 以sklearn中的手写数字datasets.load_digits为例,其是8*8的图形,具有64个特征值,类别由0到9 我们挑选出666这个图形,将其可视化 X = dig ...

  9. Sqli-Labs less25-25a

    less-25 前置基础知识:后面的关卡涉及到WAF绕过: 主要有三种方式:白盒绕过.黑盒绕过.fuzz测试 网上sql注入WAF绕过的教程有很多,可以自己查询,总之就是比谁思路猥琐 根据第25关下面 ...

  10. ubuntu18.4 与pc notepad++ 使用nppftp

    首先在linux上部署 vsftpd 安装过程可能有一些问题.我之前的一个文章有所说明. 然后更改配置文件 vsftpd.conf 最简单是开启匿名登录,有时候还要开启root登录,在user文件里面 ...