import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import javax.crypto.spec.IvParameterSpec; public class DESUtil { private final static String algorithm = "DES"; /** * @return DES算法密钥 */ public static byte[] generateKey() { try { // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); // 生成一个DES算法的KeyGenerator对象 KeyGenerator kg = KeyGenerator.getInstance(algorithm); kg.init(sr); // 生成密钥 SecretKey secretKey = kg.generateKey(); // 获取密钥数据 byte[] key = secretKey.getEncoded(); return key; } catch (NoSuchAlgorithmException e) { System.err.println("DESAlgorithmGenerateKeyError"); e.printStackTrace(); } return null; } /** * 加密函数 * * @param data * 加密数据 * @param key * 密钥 * @return 返回加密后的数据 */ public static byte[] encrypt(byte[] data, byte[] key) { try { // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); // 从原始密钥数据创建DESKeySpec对象 DESKeySpec dks = new DESKeySpec(key); // 创建一个密匙工厂,然后用它把DESKeySpec转换成 // 一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(algorithm); SecretKey secretKey = keyFactory.generateSecret(dks); // using DES in ECB mode Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); // 用密匙初始化Cipher对象 cipher.init(Cipher.ENCRYPT_MODE, secretKey, sr); // 执行加密操作 byte encryptedData[] = cipher.doFinal(data); return encryptedData; } catch (Exception e) { System.err.println("DESAlgorithmEncryptError"); e.printStackTrace(); } return null; } /** * 解密函数 * * @param data * 解密数据 * @param key * 密钥 * @return 返回解密后的数据 */ public static byte[] decrypt(byte[] data, byte[] key) throws Exception { try { // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); // byte rawKeyData[] = /* 用某种方法获取原始密匙数据 */; // 从原始密匙数据创建一个DESKeySpec对象 DESKeySpec dks = new DESKeySpec(key); // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成 // 一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(algorithm); SecretKey secretKey = keyFactory.generateSecret(dks); // using DES in ECB mode Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); // 用密匙初始化Cipher对象 cipher.init(Cipher.DECRYPT_MODE, secretKey, sr); // 正式执行解密操作 byte decryptedData[] = cipher.doFinal(data); return decryptedData; } catch (Exception e) { // System.err.println("DESAlgorithmDecryptError"); // e.printStackTrace(); throw e; } } /** * 加密函数--CBC模式 * * @param data * 加密数据 * @param key * 密钥 * @return 返回加密后的数据 */ public static byte[] CBCEncrypt(byte[] data, byte[] key, byte[] iv) { try { // 从原始密钥数据创建DESKeySpec对象 DESKeySpec dks = new DESKeySpec(key); // 创建一个密匙工厂,然后用它把DESKeySpec转换成 // 一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(algorithm); SecretKey secretKey = keyFactory.generateSecret(dks); // Cipher对象实际完成加密操作 Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); // 若采用NoPadding模式,data长度必须是8的倍数 // Cipher cipher = Cipher.getInstance("DES/CBC/NoPadding"); // 用密匙初始化Cipher对象 // IvParameterSpec param = new IvParameterSpec(iv); cipher.init(Cipher.ENCRYPT_MODE, secretKey); // 执行加密操作 byte encryptedData[] = cipher.doFinal(data); return encryptedData; } catch (Exception e) { System.err.println("DESCBCAlgorithmEncryptError"); e.printStackTrace(); } return null; } /** * 解密函数--CBC模式 * * @param data * 解密数据 * @param key * 密钥 * @return 返回解密后的数据 */ public static byte[] CBCDecrypt(byte[] data, byte[] key, byte[] iv) { try { // 从原始密匙数据创建一个DESKeySpec对象 DESKeySpec dks = new DESKeySpec(key); // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成 // 一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(algorithm); SecretKey secretKey = keyFactory.generateSecret(dks); // using DES in CBC mode Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding"); // 若采用NoPadding模式,data长度必须是8的倍数 // Cipher cipher = Cipher.getInstance("DES/CBC/NoPadding"); // 用密匙初始化Cipher对象 IvParameterSpec param = new IvParameterSpec(iv); cipher.init(Cipher.DECRYPT_MODE, secretKey, param); // cipher.init(Cipher.DECRYPT_MODE, secretKey); // 正式执行解密操作 byte decryptedData[] = cipher.doFinal(data); return decryptedData; } catch (Exception e) { System.err.println("DESCBCAlgorithmDecryptError"); e.printStackTrace(); } return null; } public static void main(String[] args) throws Exception { // try { // byte[] key = "11111111".getBytes(); // byte[] iv = "22222222".getBytes(); // byte[] data = DESUtil.encrypt("ebc mode test 中文".getBytes(), key); // System.out.print("EBC mode:"); // System.out.println(new String(DESUtil.decrypt(data, key))); // // System.out.print("CBC mode:"); // data = DESUtil.CBCEncrypt("cbc mode test".getBytes(), key, iv); // System.out.println(new String(DESUtil.CBCDecrypt(data, key, iv))); // // } catch (Exception e) { // e.printStackTrace(); // } // for(int i=0;i<100;i++){ // System.out.println(ByteUtil.bytesToHexstr(DESUtil.generateKey())); // } String s = ""; String encryptString = "68d2455f8cf9d10055a532642b2650bfb1204e0e9a6dff146855a95256a8ce63e44380c06288413aa62e43089b1c94db257ea4125cafa9486038df9fbe2e2e02820f15bc155aab97357583a11003ec02b39f39c40c2bc6d04fc23def85e0ae3ea0efb2511add385d2b21aa52795fed816c6a420d4f560d0c"; encryptString = "68d2455f8cf9d10055a532642b2650bfb1204e0e9a6dff146855a95256a8ce63e44380c06288413aa62e43089b1c94db257ea4125cafa9486038df9fbe2e2e02820f15bc155aab97357583a11003ec02b39f39c40c2bc6d04fc23def85e0ae3ea0efb2511add385d2b21aa52795fed816c6a420d4f560d0c"; String key = "ac1e7a28"; byte[] encryptByte = ByteUtil.hexstrTobytes(encryptString); System.out.println(); System.out.println(new String(encryptByte)); byte[] res = null; long start = System.currentTimeMillis(); res = DESUtil.decrypt(encryptByte, key.getBytes()); long end = System.currentTimeMillis(); System.out.println(end - start); System.out.println(new String(res)); } }
捐助开发者
在兴趣的驱动下,写一个免费
的东西,有欣喜,也还有汗水,希望你喜欢我的作品,同时也能支持一下。 当然,有钱捧个钱场(右上角的爱心标志,支持支付宝和PayPal捐助),没钱捧个人场,谢谢各位。
谢谢您的赞助,我会做的更好!
相关推荐
DES加密解密程序的C源码.喜欢就下~~~
DES加密 解密 方法: DESr DESw 支持3DES加密 解密 类中利用函数重载的方式 实现两种加密方式 加密后为16进制字符串 使用方法: 实例化一个对象 然后就可以随便用了。 如 DES加密 解密 CString sd,sd2; yxyDES2 ...
DES加密解密算法的C语言实现,只要调用函数,即可实现数据的加密解密,我已经在DSP上实现。
DES加密解密程序,VC源码值得学习借鉴
DES加密解密(c++实现)
des加密解密工具
对数据进行3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
VB实现DES加密解密算法已测试通过如有更新另行发布
DES加密解密过程,C++实现
DES加密解密实验报告,内容详细,尤其是实验原理部分写的很多,另外重点研究了DES的弱密钥问题,有运行结果截图,没有源代码。
des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现des加密解密java实现
DES加密解密算法 C语言源代码,STM32 51单片机可用。提高产品的安全性,RAM占用小。 /* DES加密,binput:明文,boutput:密文, bkey:密钥 */
VC++6.0 DES加密解密示例工程,包含两个加密解密类库,实例化后即可使用
纯C语言实现的DES加密解密算法,直接用VC++6.0运行即可
加密解密算法的可执行程序实现des加密解密以及3des加密解密
一个调用动态链接库的des加密解密例子。
基于matlab的数字图像des加密解密研究.pdf
C++ DES加密解密 封装成类了 此代码是测试工具,实现字符串加密解密/文件加密解密。KEY可使用2个 支持中文。 VS2010运行代码
vue DES加密解密工具类 des.js,与博文中的匹配,为封装好的完整工具类
java des加密解密jar包,实现了utf-8防止乱码,这个是jar包,可以直接使用,需要源码可以找我