加密类型及其相关算法

加密类型及其相关算法

§·TCP/IP安全:

※·机密性:

数据在网络上传输是明文传输(ftphttpsmtptelnet):

※·数据的完整性:

数据在网络上传输,不能被其它人篡改,保证数据的完整性:

※·身份验证:

访问的主机有一种机制可以表明就是你需要通信的主机。

※·保证机密性:对数据进行加密。

·如何加密:发送方通过转换规(转换算法)则把明文转换为密文;

·如何解密:接收方通过转换规(转换算法)则把密文转换为明文即可:

提问:双方每见过面如何知道使用何种算法?

·转换算法是复杂的数学原理,如果转换算法被拿走怎么办?

注意一点:转换算法人人都可以取得,但是我们实际使用的主要还是密钥。

※·机密性保证机制(加密机制 密钥)

·对称加密:

分为加密算法和解密算法,本身是两种不同的算法,不过使用的密钥是一样,使用相同的密钥加密和解密数据。 

注意:如何用户A与不同用户通信时,不可能使用相同的密钥,如果使用相同的密钥,A与其他用户通信,密钥要是公开了,A与其他人的数据都会被别人知道,所以在实际中,A不可能使用相关的密钥与其他用户通信。

※·数据完整性保证机制(单向加密算法)

保证数据还是最原始的数据,保证数据本身是它本身,我们使用单项加密算法。

·单项加密算法:提取数据的特征码(相当于把数据的指纹信息提起出来)。

A有一段明文,通过单向加密算法,提取出明文的特征码,把特征码附加在明文后面;

B收到数据后,通过单向加密算法,也提取出明文的特征码,比较两段特征码是否一致;

·单向加密算法:提取数据特征码:

输入一样,输出必然相同;

雪崩效应:输入的微小变化,将会引起结果的巨大变化;

定长输出:无论原始数据多长,结果大小都相同的;

不可逆:无法根据特征码还原原来的数据。

注意:如果出现这种情况,AB传输数据,并且通过单项加密算法生成特征码,C截取A发送的数据,提取出明文后,修改数据,再使用相同的单项加密算法生成特征码,把数据传输给BB同样还是可以计算出特征码,肯定与C的特征码是一样,导致数据被篡改,而B不知道。 

·如何预防C如果篡改了数据,B可以发现呢(AB协商相同密码对特征码进行加密)?

可以再来对特征码进行加密,前提是 A B 需要协商相同的密码对特征码进行加密,只有AB协商的密码才可以解密特征码的数据。即使C截取到数据,无法解密特征码数据,即使C修改了数据,生成的特征码再发送BB无法使用协商好的密码进行解密,即可认为数据被篡改过。 

·如何预防A B协商的密码在网络上传输不被别人知道呢?(IKE(互联网密钥交换 )协商生成密码)

Diffie-Hellman协议:实现互联网密钥交换 (Internet  Key  Exchange  IKE

第一阶段:

A : 选择一个大素数(离散数学对数)  p

B : 选择一个大素数 :g

p  g可以通过网络交换,使得A B 都知道 p   g

第二阶段:

A :本地随机一个数 : x

A : g ^x%p 的结果发送给 B

B:本地随机一个数 :  y

B : g^y%p 的结果发送给  A

注意:在互联网上就只有四个数字的传输: p  g   g ^x%p  g^y%p ,根据离散数学原理,x  y 这两个数字是不可能被计算出来的

第三阶段:

A :就取得B发给自己的:g^y%p  A是知道自己的随机数x的)

B:就取得A发给自己的: g ^x%p   B是知道自己的随机数y的)

A B协商的密码为 :  g^xy%p 

Diffie-Hellman协议:可以通过软件管理每次的特征码加密的密码,不需要人为的参与。

※·身份验证保证机制(非对称加密算法)

以上解决的是数据的机密性与数据完整性。但是如何保证数据的身份信息呢?

公钥加密算法:非对称加密算法

密钥对:

公钥 p (是通过某中机制从私钥中提取出来的)

私匙 s  (私钥一般情况下非常长有1024 2048 4096位) 

发送方使用自己的私钥加密数据,可以实现身份验证;

发送方使用对方的公钥加密数据,可以保证数据机密性; 

公钥机密算法很少用来加密数据,速度太慢,公钥太长了;

通常情况下:对称加密是公钥加密数据速度的1000 

如下模型:

加密解密.jpg 

这个模型保证了身份验证的问题,但是无法保证数据的机密性。

※·如何获取用户的公钥(如何获取真正的公钥),保证数据机密性

·获取用户公钥

由于双方建立通信的第一次根本就无法确定对方的身份,根本就无法获取到对方的公钥,需要公钥就需要先通信,但是先通信就得需要对方的公钥加密数据,死循环。

我们就必须借助第三方信任机构,自己生成公钥和私钥,把自己的公钥想办法放在第三方信任机构上,其它用户想办法在第三方机构取得对方的公钥。

第三方信任机构把用户的公钥颁发证书:

姓名:住址:公钥:第三方信息机构私钥加密数据  ————–> 生成数字证书

第三方信任机构为:CA

§·网络传输上的数据加密 解密模型(基于IKE

 IKE加密解密.jpg

§·实际运行中数据加密 解密模型(基于随机密码)

随机密码-加密解密.jpg 

 

原创文章,作者:linux_root,如若转载,请注明出处:http://www.178linux.com/43920

(1)
上一篇 2016-09-06 13:00
下一篇 2016-09-06 15:21

相关推荐

  • 数据库存储引擎—InnoDB

    MySQL中的数据用各种不同的技术存储在文件(或者内存)中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不同的功能和能力。通过选择不同的技术,你能够获得额外的速度或者功能,从而改善你的应用的整体功能。

    Linux干货 2018-02-22
  • LVM逻辑卷管理器详解

    一、LVM简介 LVM是 Logical Volume Manager(逻辑卷管理)的简写,它由Heinz Mauelshagen在Linux 2.4内核上实现。LVM将一个或多个硬盘的分区在逻辑上集合,相当于一个大硬盘来使用,当硬盘的空间不够使用的时候,可以继续将其它的硬盘的分区加入其中,这样可以实现磁盘空间的动态管理,相对于普通的磁盘分区有很大的灵活性。…

    Linux干货 2016-09-05
  • echo address

    echo address

    Linux干货 2016-08-08
  • 第八周-Linux网络配置,软件安装,bash编程

    1、请描述网桥、集线器、二层交换机、三层交换机、路由器的功能、使用场景与区别 网桥:一种网络设备,负责网络桥接(network bridging)之用。桥接器将网络的多个网段在数据链路层(OSI模型第2层)连接起来(即桥接)。 集线器(Hub):是指将多条以太网双绞线或光纤集合连接在同一段物理介质下的设备。集线器是运作在OSI模型中的物理层。 二层交换机:工…

    Linux干货 2016-11-14
  • 简单易懂的CentOS启动流程

    在使用Linux操作系统时,我们只需要按下电源键,等待一会儿,登录终端就呈现在我们眼前,在这段时间内,操作系统究竟做了哪些事情? 先上一张流程梗概图,你会对启动流程有个大致的了解 启动流程详解 POST加电自检   主板在接通电源后,系统首先由POST程序来对CPU、主板、内存、硬盘子系统、显示子系统串并行接口、键盘、CD-ROm光驱等硬件进行检测 读取MB…

    Linux干货 2016-09-11
  • Linux 2.6.39-rc3的一个插曲

    2011年4月12日,Linux 2.6.39-rc3发布了,Linus Torvalds写了一个发布邮件,其中包含了一个长长的为这个版本做过贡献的人员名单,这个名单中有很多看上去应该是中国人的名字,我挺为他们感到骄傲的(不知道你是否还记得以前本站的”Linux是由谁写的“)。 不过,没过一会,发现了一个bug,经过大家的调查(2.6.38版没有发现这个问题…

    Linux干货 2016-06-09