DES算法的两种模式ECB和CBC问题以及更加安全的算法——3DES算法。

一、数据补位 DES数据加解密就是将数据按照8个字节一段进行DES加密或解密得到一段8个字节的密文或者明文,最后一段不足8个字节,按照需求补足8个字节(通常补00或者FF,根据实际要求不同)进行计算,之后按照顺序将计算所得的数据连在一起即可。 这里有个问题就是为什么要进行数据补位?主要原因是DES算法加解密时要求数据必须为8个字节。

二、ECB模式 DES ECB(电子密本方式)其实非常简单,就是将数据按照8个字节一段进行DES加密或解密得到一段8个字节的密文或者明文,最后一段不足8个字节,按照需求补足8个字节进行计算,之后按照顺序将计算所得的数据连在一起即可,各段数据之间互不影响。

三、CBC模式 DES CBC(密文分组链接方式)有点麻烦,它的实现机制使加密的各段数据之间有了联系。其实现的机理如下: 加密步骤如下: 1)首先将数据按照8个字节一组进行分组得到D1D2......Dn(若数据不是8的整数倍,用指定的PADDING数据补位) 2)第一组数据D1与初始化向量I异或后的结果进行DES加密得到第一组密文C1(初始化向量I为全零) 3)第二组数据D2与第一组的加密结果C1异或以后的结果进行DES加密,得到第二组密文C2 4)之后的数据以此类推,得到Cn 5)按顺序连为C1C2C3......Cn即为加密结果。 解密是加密的逆过程,步骤如下: 1)首先将数据按照8个字节一组进行分组得到C1C2C3......Cn 2)将第一组数据进行解密后与初始化向量I进行异或得到第一组明文D1(注意:一定是先解密再异或) 3)将第二组数据C2进行解密后与第一组密文数据进行异或得到第二组数据D2 4)之后依此类推,得到Dn 5)按顺序连为D1D2D3......Dn即为解密结果。 这里注意一点,解密的结果并不一定是我们原来的加密数据,可能还含有你补得位,一定要把补位去掉才是你的原来的数据。

四、3DES 算法 3DES算法顾名思义就是3次DES算法,其算法原理如下: 设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的密钥,P代表明文,C代表密表,这样, 3DES加密过程为:C=Ek3(Dk2(Ek1(P))) 3DES解密过程为:P=Dk1((EK2(Dk3(C))) 这里可以K1=K3,但不能K1=K2=K3(如果相等的话就成了DES算法了) 3DES with 2 diffrent keys(K1=K3),可以是3DES-CBC,也可以是3DES-ECB,3DES-CBC整个算法的流程和DES-CBC一样,但是在原来的加密或者解密处增加了异或运算的步骤,使用的密钥是16字节长度的密钥,将密钥分成左8字节和右8字节的两部分,即k1=左8字节,k2=右8字节,然后进行加密运算和解密运算。 3DES with 3 different keys,和3DES-CBC的流程完全一样,只是使用的密钥是24字节的,但在每个加密解密加密时候用的密钥不一样,将密钥分为3段8字节的密钥分别为密钥1、密钥2、密钥3,在3DES加密时对加密解密加密依次使用密钥1、密钥2、密钥3,在3DES解密时对解密加密解密依次使用密钥3、密钥2、密钥1。

3DES、DES的CBC、ECB相关推荐

  1. golang 的AES加解密 (CBC/ECB/CFB 模式)

    golang的AES加密和解密的三种模式实现(CBC/ECB/CFB) package mainimport ("bytes""crypto/aes"" ...

  2. LINUX、C#下使用DES算法CBC模式进行对称加密、解密

    openssl是一个加密库,封装了多个算法,我们这里使用的是DES算法CBC模式. 一.准备OPENSSL的LINUX及C#库 openssl项目地址: https://www.openssl.org ...

  3. Go语言的DES加密(CBC模式, ECB模式) ---- 与java加密互通(转)

    问题场景: 业务需要对接接口, 采用DES加密方式加密, 于是google一下go的DES加密方式, go的DES的默认隐藏了ECB模式, 因为go认为ECB不安全, 所以不建议使用,就隐藏了, 然而 ...

  4. crypto++使用DES加密(ECB pkcs7padding )

    zeropadding ZeroPadding,数据长度不对齐时使用0填充,否则不填充.使用0填充有个缺点,当元数据尾部也存在0时,在unpadding时可能会存在问题. pkcs7padding 假 ...

  5. php中des加密cbc模式,php中加密解密DES类的简单使用方法示例

    本文实例讲述了php中加密解密DES类的简单使用方法.分享给大家供大家参考,具体如下: 在平时的开发工作中,我们经常会对关键字符进行加密,可能为了安全 也可能为了规范,所以要正确使用DES加密解密 代 ...

  6. C#.NET 国密SM4加密解密 CBC ECB 2种模式

    注意点: 1.加密时,明文转 byte[] 时,不要用 Encoding.Default,一定要指定编码,如:UTF-8. 解密时,解出的 byte[] 转 string 同样要指定相同的编码. 2. ...

  7. 加密机体系(要配合银联密钥体系一起看)

    版权声明:转载或使用时请注明出处与作者. https://blog.csdn.net/weixin_43177881/article/details/83034315 </div>< ...

  8. OPENSSL EVP_AES部分翻译

    需要用到Openssl的AES_128_ECB加密,网络上找了半天资料,没找到想要的,官方资料只有英文,只得硬着头皮上.怕这次读后又忘了,以后如果有需要可能还得再折腾一遍,就翻译下记录在文档上,为防止 ...

  9. java中3des cbc,js與java通用的3DES(ECB,CBC)+Base64加密編碼,解碼解密

    J S端加密過程: key的處理: 通過創建指定的key,key必須是16位/24位/32位其中一種,但是常用的3DES加密的key為24位,下面使用的就是24位,key的長度可以隨意指定,在轉換ke ...

最新文章

  1. 人工智能的鱼与熊掌:精度与可解释性
  2. redis cluster集群模式总结
  3. 从头开始复习css之2D变换
  4. HTML DOM节点的属性获取
  5. ionic 压缩和上传视频文件
  6. 第二阶段 站立会议 10
  7. python可执行文件 情人节快乐_各位情人节快乐, Python帮忙撒狗粮, 我连夜做了这个程序!...
  8. 微信网页支付之H5支付
  9. c语言中输出以e为底的指数,c语言中以e为底的指数怎么表示 c++中怎样表示以e为底的...
  10. leetcode_Restore IP Addresses
  11. php惠新宸框架,首位国人惠新宸加入PHP官方开发组
  12. Sketch插件介绍
  13. 如何解释反向代理与正向代理
  14. 软件压缩卡与硬件压缩卡的比较
  15. 深度解析FPS游戏外挂+解决方案
  16. 包头中考计算机考试试题2020,2020年内蒙古包头中考数学试卷附答案解析版.docx...
  17. SharePoint 2010 IT Professional--巧用Calendar List
  18. SSH三大框架面试题集锦
  19. 网站被挂黑链会引起哪些后果
  20. iframe中的视屏放大

热门文章

  1. 基于python的异方差检验_讲讲异方差的检验
  2. imx6ull交叉编译libmodbus
  3. Sparse Checkout 在 Monorepo 工程下的应用
  4. 电子护照阅读机产品概述
  5. 数字时代,你想成为一只“弱鸡”,还是一个“超级个体”?
  6. NOIP2015提高组初赛难点整理
  7. SeLinux问题实例:读写asce失败
  8. 【sql】case when用法
  9. 考研前辈の后悔清单,你中了多少条?
  10. webbench 下载_webbench压力测试