数据的加密和解密初识

简介:

加密是让数据从明文变成密文,传输过程中是密文,传送过去之后对方接收到的也是密文。

可以理解为密文就是乱码,看不出内在的任何意义,通常也都是逐位对应的。

在接收方接收到密文之后只有把它还原为原来的样子才可以理解对方说的具体是什么,此过程就叫做解密。


1.不同主机之间的进程间通信:Socket-pair,套接字对

  套接字Socket的三种类型:

    流套接字(Socket_Stream):基于TCP协议通信的套接字

    数据报套接字(Socket_Dgram):基于UDP协议通信的套接字

    裸套接字,原始套接字(Socket_Ram):基于底层协议通信的套接字


2.威胁安全的行为:

威胁机密性的攻击行为:

  窃听、嗅探、扫描、通信量分析

威胁完整性的攻击:

  更改、伪装、重放、否认

威胁可用性的攻击:

  拒绝服务(DoS)


3.安全实现的目标:

  机密性:confidentiality,保证信息不泄露

  完整性:integrity,保证信息不被篡改

  可用性:availability,保证信息内在价值


4.安全解决方案:

  技术:加密和解密

    传统的加密方法:替代加密算法

    现代的加密方法:块加密方法:

  服务:安全服务

    身份认证、访问控制机制


5.加密方案:

  加密算法和密钥


  加密算法


  四种加密算法:

    对称加密算法

    公钥加密算法(非对称加密)

    单向加密算法

    密钥交换算法


    1)对称加密算法:

    加密和解密使用同一密钥

    特性:

      1.每对通信主机都需要保有一个相同的密钥,用于加密和解密

      2.将原始的数据分隔成固定大小的块,逐个加密

      3.加密和解密的速度比较快    

    缺陷:

      1.加密解密所需要保有的密钥数量过多

      2.密钥分发过于困难 


    主流加密算法:

      DES:Data Encryption Standard,数据加密标准

        56bit密钥,64bit块

        3DES:triple DES

      AES:Advanced Encryption Standard高级加密标准

        AES128bit,AES192bit,AES256bit

      Blowfish

      Twofish

      IDEA

      RC

      RC4,RC6


  2)公钥加密算法:

    密钥分为私钥和私钥抽取生成的公钥组成

    私钥:512bit,1024bit,2048bit,4096bit,8192bit,16384bit

    特点:

      1.使用密钥对来加密和解密,使用私钥加密的数据必须用从中抽取出的公钥解密,同样如果使用公钥加密必须使用与之相对的私钥进行解密

        私钥:通过特定的工具创建生成,由使用者自己留存,务必保证其私密性,secret key,或者private key

        公钥:从私钥中提取产生,公钥可以公开给所有人使用public key

      2.密钥长度比较长,加密后的数据安全等级较高

    缺陷:

      加密数据的时候,消耗的系统资源和时间都较多,很少用来加密大批量数据

    用途:

      数字签名:主要用于让接收方确认发送方的身份,使用发送方的私钥发送数据,到了接收方之后,使用发送方的公钥解密数据

      密钥交换:发送数据的一方使用接受方的公钥加密对称密钥,将加密后的对称密钥发送给对方 

      数据加密:通常用于加密小数据


    常用的公钥加密算法:

      RSA:加密,数字签名

      DSA:数字签名算法,Digital signature Algorithm,数字签名算法,只能实现数字签名的功能,有时候该算法被称为DSS,Digital Signature Standard

      Elgamal:


  3)单项加密:

    只能进行加密,不能进行解密,从已知数据中提取密码指纹

    特性:

      1.定长输出

      2.雪崩效应

    功能:

      保证数据的完整性

    常用的算法:

      md5:massage digest version 5 ,信息摘要算法的第五版

        128bit定长输出

      sha系列:

        sha-1:secure hash algorithm,安全哈希算法,160bit定长输出

        sha224

        ssh256

        ssh384

        ssh512


  4)密钥交换算法:IKE(Internet key exchange)

    公钥加密

    DH算法:deffie-hellman


  密钥


国际标准化组织(ISO)定义了证书的结构和认证标准:X.509协议标准

证书里面包括的:

  拥有者的名称

  拥有者所提交的公钥信息

  有效期

  证书的版本号

  证书的序列号

  签发算法ID

  签发CA的名称

  主体名称

  签发机构的唯一标识

  签发机构的数字签名

  扩展信息


PKI:public key infrastructure,公钥基础设施

  证书的签证机构:CA

  注册机构:RA

  证书吊销列表:CRL,certification Revoke List

  证书存取库:CAB,certification Access Base


CA如何发挥其作用:

  1.通信双方互相交换证书,

  2.双方协商加密算法

  3.双方验证证书的真伪

  4.CA的公钥解密证书的CA的签名,能解密说明证书来源可靠

  5.同样的加密算法加密证书,取得特征值,与解密出来的特征值比较,如果相同说明证书完整性可靠

  6.检查证书的有效期是否在合法范围内,如果过期则证书不被认可

  7.检查证书的主体名称和此次通信的目标是否能够对应


  SSL:Secure Socket Layer,安全的套接字层


TLS:Transport Layer Security,传输层安全

  IETF:Internet Engineering Task Force,互联网工程项目小组

  分层设计:

    1.最底层:实现基础算法的原语的实现,AES,md5,sha...

    2.向上一层:各种算法的基本实现

    3.再向上一层:各种算法组合实现的半成品

    4.最高层:各种组件拼装而成的各种成品密码学协议软件


SSL/TLS的handshake(握手)的四个阶段:

  1.客户端向服务器索要证书,并验证证书是否合法

    Client Hello发送的信息内容

      支持的协议版本,如:TLS V1.2

      客户端生成一个随机数,稍后用户生成会话密钥

      支持的加密算法,如:AES,DES,RSA等

      支持的压缩算法


  2.双方协商生成会话密钥

    Server Hello发送的信息内容

      确认使用的加密协议的版本号,如 TLS V1.2

      服务器生成一个随机数,稍后用于生成会话密钥

      确认加密算法及压缩算法


  3.双方采用已经生成的会话密钥进行安全加密的通信

    客户端验证服务器证书,在确认无误后取出其公钥


    验证服务器证书需要验证下述内容:

      验证发证机构(CA)

      验证证书的完整性

      验证证书的持有者信息

      验证证书的有效期

      验证证书的吊销列表


    客户端发送信息给服务器端

      一个随机数,用于服务器上的公钥加密

      编码格式变更的通知,表示随后的信息都将用双方已经协商好的加密算法和秘钥进行加密发送 


    客户端握手结束


  4.双方互相通告握手结束的信息

    服务器收到客户端发送来的此次握手阶段的第三个随机数Pre-Master-key,计算生成本次会话所用到的会话密钥,向客户端发送相关信息

      编码变更通知,表示随后的信息都将用双方已经协商好的加密算法和密钥进行加密发送,


    服务器端握手结束

  


本文转自 Runs_ 51CTO博客,原文链接:http://blog.51cto.com/12667170/1953488,如需转载请自行联系原作者

相关文章
|
2月前
|
JSON 小程序 数据安全/隐私保护
小程序动态调试-解密加密数据与签名校验
本文主要讲解微信小程序加密、验签的情况下如何进行动态调试已获取签名以及加密信息
|
2月前
|
SQL 数据库 数据安全/隐私保护
sql注入碰到加密数据怎么办
sql注入碰到加密数据怎么办
19 1
|
3月前
|
JSON 数据安全/隐私保护 数据格式
|
5月前
|
存储 SQL 关系型数据库
MySql加密存储的数据,如何模糊搜索?
MySql加密存储的数据,如何模糊搜索?
81 0
|
6月前
|
JavaScript 安全 数据安全/隐私保护
JS逆向 -- 分析被加密的响应数据
JS逆向 -- 分析被加密的响应数据
37 0
|
8月前
|
数据采集 JavaScript API
Python爬虫抓取经过JS加密的API数据的实现步骤
Python爬虫抓取经过JS加密的API数据的实现步骤
|
8月前
|
安全 数据安全/隐私保护
一分钟教会你如何使用Crypto模块RSA非对称加密,把重要的数据进行加密
随着互联网的迅速发展,信息安全变得尤为重要。数据加密是一个必不可少的环节。有时候,我们一不留神,可能数据就被人窃听到。今天跟大家分享一个数据加密的小案例。
167 0
|
9月前
|
存储 安全 网络安全
解密Globeimposter-Alpha865qqz勒索病毒:如何恢复被加密的数据文件?
随着数字化时代的到来,网络安全威胁也日益增加,其中勒索病毒是当前备受关注的问题之一。Globeimposter-Alpha865qqz勒索病毒作为其中的一种,已经给无数用户带来了沉重的打击和困扰。91数据恢复将在本文深入探讨Globeimposter-Alpha865qqz勒索病毒的特点,并提供一些可能的解密方法,帮助用户恢复被加密的数据文件。
|
9月前
|
供应链 安全 网络安全
.360勒索病毒的加密数据怎么处理?|.360勒索病毒数据解密恢复
​ .360勒索病毒是一种恶意软件,它对用户的计算机文件进行加密,并要求支付赎金才能解密恢复数据。这种勒索病毒以其广泛传播和严重破坏性而闻名,给个人用户和企业带来了巨大的困扰和损失。
95 0
.360勒索病毒的加密数据怎么处理?|.360勒索病毒数据解密恢复
|
10月前
|
存储 安全 算法
locked勒索病毒利用零日漏洞,企业服务器数据瞬间遭受致命加密
近日,网络安全界再次爆发了一起令人震惊的事件,一种名为"Locked"的勒索病毒利用软件中的零日漏洞,迅速传播并瞬间加密了大量企业服务器。这一事件引发了广泛的关注和恐慌,暴露出网络安全的脆弱性和企业在面对新兴威胁时的不足之处。91数据恢复在本文将对这一事件进行深入分析,探讨相关的影响和可能的防范措施。
locked勒索病毒利用零日漏洞,企业服务器数据瞬间遭受致命加密