加密第四节_IPSec基本理论

本节内容

  1. IPSec简介
  2. IPSec两种工作模式
  3. 判断隧道模式和传输模式
  4. IPSec两种模型
  5. IPSec两个数据库

IPSec基本理论

IPSec简介

  • 提供了网络层的安全;
  • 在明文的IP头部和网络层数据之间插入了一个IPSec的头部,保证了网络负载的安全。
  • IPSec头部有ESP头部和AH头部两种;
  • 是IPV6的强制部分

IPSec组成部分:

  • ESP(负载安全封装)协议;
  • 认证头(AH)协议;
  • Internet秘钥交换(IKE)协议

IPSec两种工作模式:

传输模式:在IP头部和网络层数据之间插入了一个头部

隧道模式: 将原始数据封装到里面,然后在外面插入IPSec头部,再在外面插入一个新的IP头部

判断隧道模式和传输模式:

第一种判断方法:加密点:两个配置了VPN的通讯设备;通讯点:两个需要通讯的网络设备
加密点不等于通讯点为隧道模式

第二种判断方法:两通讯设备中间的承载网络是全局可路由的是传输模式;若中间承载网络不是全局可以路由的是隧道模式。

IPSec两种模型

站点到站点模型和远程接入模型

IP层协议号:1->icmp;6->tcp;17->udp;47->gre;50->esp;51->ah

ESP介绍:协议号是50;不加密原始IP头部;提供私密性,数据完整性和数据源认证(HMAC);能够抵御重放攻击。
ESP包结构

SPI:一个32位的值,用来唯一标识一个安全关联(SA)用来处理这个包
SA(安全关联):双方所有协商的结果的集合
序列号:抵御重放攻击,收到相同序列号的包,将丢弃后面收到的包,只保留第一次收到该序列号的包
IV位:加密的时候会产生IV位,不加密时没有IV位
垫片(padding):标识垫片
padding length(垫片长度):用来补齐类似于DES的64bit加密数据
Report Handler(下一个头部)
ESP traller(esp尾部)
ESP认证块:96bit长度,整块从ESP头部到尾部的数据做哈希,得到的值放到ESP认证块中

AH介绍:协议号是51;完整性校验和和源认证;能防重放攻击;不能提供数据加密(严重问题);IP头部部分被认证,包括版本号,载荷长度,总长度,标示符,IP协议,源IP地址,目的IP地址,因为IP地址需要被认证,所以AH不能穿越NAT(严重问题)因为存在这两个问题,所以一般不会使用AH
AH包结构

IPSec两个数据库

SPD(安全策略数据库):SPD决定了什么流量将接受IPSec处理
SADB(安全关联数据库):SADB维护每一个SA(安全关联)包含的参数

SPD(安全策略数据库)
选择器选择感兴趣流加密,可以通过源IP,目的IP,名字,传输层协议,源目端口号来进行选择
选择流量后有三种处理方式:旁路,不管它;丢弃和IPSec加密。
SPD中每一个条目都与SA关联

SADB(安全关联数据库)
在SADB里面的每一个条目决定了一个特定SA的参数,当一个IPSec SA被创建,SADB更新所有关于这个SA的参数。当一个inbound IPSec数据包抵达,SADB基于外层IP头部的目的IP地址,SPI和IPSec封装协议(ESP/AH)检索数据库以获得相应的SA,然后用这个SA的相关参数处理这个inbound IPSec数据包。对于outbound IPSec数据包处理的相关参数,是由SPD相关联的SA来获取的。
示意图

SA包含的9大部分

  1. 序列号
  2. 序列号溢出位(序列号有32位,溢出之后重新开始)
  3. 防重放窗口,默认是64位
  4. SA的生存时间,分为软时间和硬时间,SA在到期前一段时间会申请新的KEY,在KEY生效到申请新KEY之间这段时间叫软时间
  5. 模式(传输模式和隧道模式)
  6. AH验证算法
  7. ESP验证算法
  8. ESP加密算法
  9. path MTU(在该方向最小的MTU,从A->B过程中最小的MTU)

什么是SA(安全关联)
SA是IPSec的一个基本组成部分,SA是SADB的一个条目,它包含双方关于IKE和IPSec已经协商完毕的安全信息

两种SA
IKE SA或者叫ISAKMP SA:1双向;2决定了IKE协议处理相关细节
IPSec SA:1单向的;2与封装协议相关;3决定了具体加密流量的处理
两种类型的SA都由IKE协议协商产生

加密第四节_IPSec基本理论的更多相关文章

  1. 大白话5分钟带你走进人工智能-第四节最大似然推导mse损失函数(深度解析最小二乘来源)(2)

    第四节  最大似然推导mse损失函数(深度解析最小二乘来源)(2) 上一节我们说了极大似然的思想以及似然函数的意义,了解了要使模型最好的参数值就要使似然函数最大,同时损失函数(最小二乘)最小,留下了一 ...

  2. 第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册

    第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册 基于类的路由映射 from django.conf.urls import url, incl ...

  3. 风炫安全WEB安全学习第二十四节课 利用XSS钓鱼攻击

    风炫安全WEB安全学习第二十四节课 利用XSS钓鱼攻击 XSS钓鱼攻击 HTTP Basic Authentication认证 大家在登录网站的时候,大部分时候是通过一个表单提交登录信息. 但是有时候 ...

  4. android内部培训视频_第四节(1)_异步网络操作

    第四节(1):异步网络操作  一.结合asyncTask下载网络图片 1.定义下载类,继承自asyncTask,参数分别为:String(url地址),Integer(刻度,本例没有用到),BitMa ...

  5. Centos7 install Openstack - (第四节)添加计算服务(Nova)

    Centos7 install Openstack - (第四节)添加计算服务(Nova) 我的blog地址:http://www.cnblogs.com/caoguo 该文根据openstack官方 ...

  6. 第四节,Linux基础命令

    第四节,Linux基础命令 命令是系统操作员对系统传入的指令,传入指令后回车,系统接收到指令做出相应的行为 1.查看用户位于系统什么位置 [pmd]检查操作用户位于系统的什么位置 命令         ...

  7. VUE2.0实现购物车和地址选配功能学习第四节

    第四节 v-on实现金额动态计算 用¥金额 进行格式处理,可以使用原生js进行转换,但是在vuei,使用filter过滤器更加方便 注: 1.es6语法=>和import等 好处在于res参数后 ...

  8. delphi 线程教学第四节:多线程类的改进

    第四节:多线程类的改进   1.需要改进的地方   a) 让线程类结束时不自动释放,以便符合 delphi 的用法.即 FreeOnTerminate:=false; b) 改造 Create 的参数 ...

  9. 大白话5分钟带你走进人工智能-第十四节过拟合解决手段L1和L2正则

                                                                               第十四节过拟合解决手段L1和L2正则 第十三节中, ...

随机推荐

  1. 实现对第三方应用任意SO注入

    实现对第三方应用任意SO注入 0x01 应用在Android中运行,从外部对该进程可以进行任意SO文件动态注入,就是应用动态运行我们的SO文件 0x02 基本的逻辑是: 1.    获取目标进程的pi ...

  2. 深入浅出Node.js(上)

    (一):什么是Node.js Node.js从2009年诞生至今,已经发展了两年有余,其成长的速度有目共睹.从在github的访问量超过Rails,到去年底Node.jsS创始人Ryan Dalh加盟 ...

  3. [转]AOP那些学术概念—通知、增强处理连接点(JoinPoint)切面(Aspect)

    AOP那些学术概念—通知.增强处理连接点(JoinPoint)切面(Aspect) 1.我所知道的AOP 初看起来,上来就是一大堆的术语,而且还有个拉风的名字,面向切面编程,都说是OOP的一种有益补充 ...

  4. gstreamer——文档/资源/使用

    http://gstreamer.freedesktop.org/src/ http://gstreamer.freedesktop.org/data/doc/gstreamer/head/qt-gs ...

  5. Python编程-数据类型方法

    一.进制简介 进制也就是进位制,是人们规定的一种进位方法.对于任何一种进制---X进制,就表示某一位置上的数运算时是逢X进一位.十进制是逢十进一,十六进制是逢十六进一,二进制就是逢二进一,以此类推,x ...

  6. 主攻ASP.NET.4.5.1 MVC5.0之重生:政府行政网站常用友情链接跳转javascript[干货分享]

    <!-----------------------------------> <script language="JavaScript" type="t ...

  7. 如何在windows10环境下安装Pytorch-0.4.1版本

    开始是按照教程:https://blog.csdn.net/xiangxianghehe/article/details/80103095 安装了Pytorch0.4.0,但是安装后发现在import ...

  8. 普通神经网络和RNN简单demo (一)

    2017-08-04 花了两天时间看了下神经网络的一点基础知识,包括单层的感知机模型,普通的没有记忆功能的多层神经网咯,还有递归神经网络RNN.这里主要是参考了一个博客,实现了几个简单的代码,这里把源 ...

  9. 语义web相关概念

    前言:最近做的项目是自然语言处理相关的,看了一本书<语义web技术基础>,总的来看,接触自然语言处理,语义理解也有差不多一年的时间了.这两天想了一想,自己究竟学到了什么,掌握了哪些新的知识 ...

  10. Apache与Tomcat三种连接方式JK、http_proxy、ajp_proxy

    为什么要让Apache与Tomcat之间进行连接?事实上Tomcat本身已经提供了HTTP服务,该服务默认的端口是8080,也可以改为80.既然Tomcat本身已经可以提供动态加静态web服务,为什么 ...