Java实现DES加解密算法解析
本文实例讲述了java实现des加解密算法解析。分享给大家供大家参考,具体如下:
简介:
数据加密算法(data encryption algorithm,dea)是一种对称加密算法,很可能是使用最广泛的密钥系统,特别是在保护金融数据的安全中,最初开发的dea是嵌入硬件中的。通常,自动取款机(automated teller machine,atm)都使用dea。它出自ibm的研究工作,ibm也曾对它拥有几年的专利权,但是在1983年已到期后,处于公有范围中,允许在特定条件下可以免除专利使用费而使用。1977年被美国*正式采纳。
1998年后实用化des破译机的出现彻底宣告des算法已不具备安全性,1999年nist颁布新标准,规定des算法只能用于遗留加密系统,但不限制使用desede算法。当今des算法正是推出历史舞台,aes算法称为他的替代者。
加密原理:
des 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 feistel 的技术,其中将加密的文本块分成两半。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但 最后一个循环不交换。des 使用 16 个循环,使用异或,置换,代换,移位操作四种基本运算。
jdk对des算法的支持
密钥长度:56位
工作模式:ecb/cbc/pcbc/ctr/cts/cfb/cfb8 to cfb128/ofb/obf8 to ofb128
填充方式:nopadding/pkcs5padding/iso10126padding/
java 加密解密之对称加密算法desede
desede 即三重des加密算法,也被称为3des或者triple des。使用三(或两)个不同的密钥对数据块进行三次(或两次)des加密(加密一次要比进行普通加密的三次要快)。三重des的强度大约和112- bit的密钥强度相当。通过迭代次数的提高了安全性,但同时也造成了加密效率低的问题。正因desede算法效率问题,aes算法诞生了。
到目前为止,还没有人给出攻击三重des的有效方法。对其密钥空间中密钥进行蛮干搜索,那么由于空间太大,这实际上是不可行的。若用差分攻击的方法,相对于单一des来说复杂性以指数形式增长。
三重des有四种模型
- des-eee3,使用三个不同密钥,顺序进行三次加密变换。
- des-ede3,使用三个不同密钥,依次进行加密-解密-加密变换。
- des-eee2,其中密钥k1=k3,顺序进行三次加密变换。
- des-ede2, 其中密钥k1=k3,依次进行加密-解密-加密变换。
java对des算法的加密代码
package com.favccxx.codelib; import java.security.securerandom; import javax.crypto.cipher; import javax.crypto.secretkey; import javax.crypto.secretkeyfactory; import javax.crypto.spec.deskeyspec; public class encryptcoder { private final static string des = "des"; public static byte[] encrypt(byte[] src, byte[] key) throws exception { // des算法要求有一个可信任的随机数源 securerandom sr = new securerandom(); // 从原始密匙数据创建deskeyspec对象 deskeyspec dks = new deskeyspec(key); // 创建一个密匙工厂,然后用它把deskeyspec转换成一个secretkey对象 secretkeyfactory keyfactory = secretkeyfactory.getinstance(des); secretkey securekey = keyfactory.generatesecret(dks); // cipher对象实际完成加密操作 cipher cipher = cipher.getinstance(des); // 用密匙初始化cipher对象 cipher.init(cipher.encrypt_mode, securekey, sr); // 正式执行加密操作 return cipher.dofinal(src); } /** * * @param password 密码 * @param key 加密字符串 * @return */ public final static string encrypt(string password, string key) { try { return byte2string(encrypt(password.getbytes(), key.getbytes())); } catch (exception e) { } return null; } public static string byte2string(byte[] b) { string hs = ""; string stmp = ""; for (int n = 0; n < b.length; n++) { stmp = (java.lang.integer.tohexstring(b[n] & 0xff)); if (stmp.length() == 1) hs = hs + "0" + stmp; else hs = hs + stmp; } return hs.touppercase(); } public static void main(string[] args){ string encryptstring = encrypt("is张三丰","test中英文杂七烂八混搭@123654{"); system.out.println(encryptstring); } //输出:b00542e93695f4cfce34fc4393c2f4bf }
java对des解密算法的实现
package com.favccxx.codelib; import java.security.securerandom; import javax.crypto.cipher; import javax.crypto.secretkey; import javax.crypto.secretkeyfactory; import javax.crypto.spec.deskeyspec; public class descryptcoder { private final static string des = "des"; /** * * @param src 数据源 * @param key 密钥,长度必须是8的倍数 * @return * @throws exception */ public static byte[] decrypt(byte[] src, byte[] key) throws exception { // des算法要求有一个可信任的随机数源 securerandom sr = new securerandom(); // 从原始密匙数据创建一个deskeyspec对象 deskeyspec dks = new deskeyspec(key); // 创建一个密匙工厂,然后用它把deskeyspec对象转换成一个secretkey对象 secretkeyfactory keyfactory = secretkeyfactory.getinstance(des); secretkey securekey = keyfactory.generatesecret(dks); // cipher对象实际完成解密操作 cipher cipher = cipher.getinstance(des); // 用密匙初始化cipher对象 cipher.init(cipher.decrypt_mode, securekey, sr); // 正式执行解密操作 return cipher.dofinal(src); } public final static string decrypt(string data, string key) { try { return new string(decrypt(string2byte(data.getbytes()), key.getbytes())); } catch (exception e) { e.printstacktrace(); } return null; } public static byte[] string2byte(byte[] b) { if ((b.length % 2) != 0) throw new illegalargumentexception("长度不是偶数"); byte[] b2 = new byte[b.length / 2]; for (int n = 0; n < b.length; n += 2) { string item = new string(b, n, 2); b2[n / 2] = (byte) integer.parseint(item, 16); } return b2; } public static void main(string[] args){ string desencryptstring = decrypt("b00542e93695f4cfce34fc4393c2f4bf","test中英文杂七烂八混搭@123654"); system.out.println(desencryptstring); } //输出:is张三丰 }
希望本文所述对你有所帮助,java实现des加解密算法解析内容就给大家介绍到这里了。希望大家继续关注我们的网站!想要学习java可以继续关注本站。