DES加密原理
DES 使用一个 56 位的密钥以及附加的 8 位奇偶校验位,产生最大 64 位的分组大小。这是一个迭代的分组密码,使用称为 Feistel 的技术,其中将加密的文本块分成两半。使用子密钥对其中一半应用循环功能,然后将输出与另一半进行“异或”运算;接着交换这两半,这一过程会继续下去,但 最后一个循环不交换。DES 使用 16 个循环,使用异或,置换,代换,移位操作四种基本运算。 解密反之。
接下来是我做测试的代码:
DES数据加密清单:
/** * DES算法密钥 */ private static final byte[] DES_KEY = { 21, 1, -110, 82, -32, -85, -128, -65 }; /** * 数据加密,算法(DES) * * @param data * 要进行加密的数据 * @return 加密后的数据 */ public static String encryptBasedDes(String data) { String encryptedData = null; try { // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); DESKeySpec deskey = new DESKeySpec(DES_KEY); // 创建一个密匙工厂,然后用它把DESKeySpec转换成一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); SecretKey key = keyFactory.generateSecret(deskey); // 加密对象 Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.ENCRYPT_MODE, key, sr); // 加密,并把字节数组编码成字符串 encryptedData = new sun.misc.BASE64Encoder().encode(cipher.doFinal(data.getBytes())); } catch (Exception e) { // log.error("加密错误,错误信息:", e); throw new RuntimeException("加密错误,错误信息:", e); } return encryptedData; }
DES数据解密清单:
/** * 数据解密,算法(DES) * * @param cryptData * 加密数据 * @return 解密后的数据 */ public static String decryptBasedDes(String cryptData) { String decryptedData = null; try { // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); DESKeySpec deskey = new DESKeySpec(DES_KEY); // 创建一个密匙工厂,然后用它把DESKeySpec转换成一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); SecretKey key = keyFactory.generateSecret(deskey); // 解密对象 Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.DECRYPT_MODE, key, sr); // 把字符串解码为字节数组,并解密 decryptedData = new String(cipher.doFinal(new sun.misc.BASE64Decoder().decodeBuffer(cryptData))); } catch (Exception e) { // log.error("解密错误,错误信息:", e); throw new RuntimeException("解密错误,错误信息:", e); } return decryptedData; }
测试清单:
public static void main(String[] args) { // TODO Auto-generated method stub String str="0123456789abcdefg"; // DES数据加密 String s1=encryptBasedDes(str); System.out.println(s1); // DES数据解密 String s2=decryptBasedDes(s1); System.err.println(s2); }
输出结果:
eUhQ+Ko1BJh5j4ok/VKL/LrUgmg0n8vV 0123456789abcdefg
相关推荐
des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现
java实现DES加密、解密算法 代码中有详细的注释,有不对或者写的不好的地方请大家指导
用java写的des算法加密及解密过程
JavaDES通过秘钥加密解密Demo
本次使用JAVA语言,采用3DES加密算法进行对文本文件的加密,通过二进制和十六进制的转换来实现,产生加密文件,再对加密文件进行解密。 关键词:DES加密算法、加密、解密。摘要 随着现代网络技术的飞速发展,人们...
Java实现AES和des对文件加密解密。Java实现AES和des对文件加密解密Java实现AES和des对文件加密解密
java 3des加密、解密工具类 java的3DES加密/解密
des加密解密算法,通过DES加密解密实现一个String字符串的加密和解密.
Java实现des加密解密算法,des加密解密算法
java的DES加密解密:用于密码在数据库的加密,解码类
java 加密解密 des 算法 用java写的des算法实现加密解密
JAVA实现DES非对称加密算法,根据秘钥对内容进行加密解密操作。
java和javascript加密解密,可相互加密解密,内含javascript代码和java代码,解压即用,自定义密钥
基于Java实现了DES正确加解密txt、jpg、docx、MP3等格式的文件,3DES以及AES加解密都实现了,除此之外,还实现了五种分组密码工作模式,内容很多。
java中常用的工具类,用于MD5的加密,里面还有切割了MD5加密的长度,有DES加密与解密,并且配有main函数可测试,可以根据自己的实际情况使用main函数测试使用
DES加密 java与.net可以相互加密解密两种方法
实现使用3des在页面js加密,后台java解密
转 JAVA加密解密DES对称加密算法.doc
java实现des加密和解密,encrypt是加密函数 decrypt是解密函数
des加密算法(js+java)加密与解密结果相同 包含三个文件 : des.js des.html ,用于实现前端脚本的加密与解密 des.java 用于后台的加密解密操作; 项目中正好用到,已经过验证,两个加密解密结果相同,分享给...