java desede 工作模式_Java 加密解密之对称加密算法DESede

JAVA

加密解密系列

Java 加密解密之对称加密算法DESede

DESede即三重 DES加密算法,也被称为3DES或者Triple  DES。使用三(或两)个不同的密钥对数据块进行三次(或两次)DES加密(加密一次要比进行普通加密的三次要快)。三重DES的强度大约和112- bit的密钥强度相当。通过迭代次数的提高了安全性,但同时也造成了加密效率低的问题。正因DESede算法效率问题,AES算法诞生了。(详见:Java 加密解密之对称加密算法AES)

到目前为止,还没有人给出攻击三重DES的有效方法。对其密钥空间中密钥进行蛮干搜索,那么由于空间太大,这实际上是不可行的。若用差分攻击的方法,相对于单一DES来说复杂性以指数形式增长。

三重DES有四种模型

(a)DES-EEE3,使用三个不同密钥,顺序进行三次加密变换。

(b)DES-EDE3,使用三个不同密钥,依次进行加密-解密-加密变换。

(c)DES-EEE2,其中密钥K1=K3,顺序进行三次加密变换。

(d)DES-EDE2, 其中密钥K1=K3,依次进行加密-解密-加密变换。

JDK对DESede算法的支持

密钥长度:112位/168位

工作模式:ECB/CBC/PCBC/CTR/CTS/CFB/CFB8 to CFB128/OFB/OBF8 to OFB128

填充方式:Nopadding/PKCS5Padding/ISO10126Padding/

工作模式和填充方式请参考:     JAVA加密解密基础

十六进制工具类Hex.java,见:DESede加密解密的java实现:DESede.java

Java代码:

import java.security.Key;

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.SecretKeyFactory;

import javax.crypto.spec.DESedeKeySpec;

/**

* DESede Coder

* secret key length: 112/168 bit, default: 168 bit

* mode: ECB/CBC/PCBC/CTR/CTS/CFB/CFB8 to CFB128/OFB/OBF8 to OFB128

* padding: Nopadding/PKCS5Padding/ISO10126Padding/

* @author Aub

*

*/</

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值