废话不多说,直接奉上代码:
代码一
package com.eabax.plugin.yundada.utils; import java.io.IOException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.spec.InvalidKeySpecException; import javax.crypto.BadPaddingException; import javax.crypto.Cipher; import javax.crypto.IllegalBlockSizeException; import javax.crypto.NoSuchPaddingException; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import org.apache.commons.codec.binary.Base64; import sun.misc.BASE64Decoder; public class DESEncryptHelper { private final static String DES = "DES"; /** * 生成密钥 * @param employeeCode */ public static String getDESKey(String encryptStr){ if (!CacheManager.getCache().containsKey("encryptKey_"+encryptStr)) { CacheManager.getCache().put("encryptKey_"+encryptStr, encryptStr+"tablemiyaokey"); } String key = (String) CacheManager.getCache().get("encryptKey_"+encryptStr); return key; } /** * Description 根据键值进行解密 * @param data * @param key 加密键byte数组 * @return * @throws IOException * @throws Exception */ public static String decrypt(String data, String key) throws IOException, Exception { if (data == null) return null; BASE64Decoder decoder = new BASE64Decoder(); byte[] buf = decoder.decodeBuffer(data); byte[] bt = decrypt(buf,key.getBytes()); return new String(bt); } /** * 对字符串加密 * @param str * @return * @throws InvalidKeyException * @throws IllegalBlockSizeException * @throws BadPaddingException * @throws InvalidKeySpecException * @throws NoSuchAlgorithmException * @throws NoSuchPaddingException */ public static String getEncryptStr(String str,String encryptStr) throws InvalidKeyException, IllegalBlockSizeException, BadPaddingException, InvalidKeySpecException, NoSuchAlgorithmException, NoSuchPaddingException { //获取key String key = getDESKey(encryptStr); //获取密钥 SecretKeyFactory factory = SecretKeyFactory.getInstance("DES"); DESKeySpec keyspec = new DESKeySpec(key.getBytes()); SecretKey deskey = factory.generateSecret(keyspec); // Cipher负责完成加密或解密工作 Cipher c = Cipher.getInstance("DES"); // 根据密钥,对Cipher对象进行初始化,DECRYPT_MODE表示加密模式 c.init(Cipher.ENCRYPT_MODE, deskey); byte[] src = str.getBytes(); // 该字节数组负责保存加密的结果 byte[] cipherByte = c.doFinal(src); String enstr = new String(Base64.encodeBase64(cipherByte)); return enstr; } /** * Description 根据键值进行解密 * @param data * @param key 加密键byte数组 * @return * @throws Exception */ private static byte[] decrypt(byte[] data, byte[] key) throws Exception { // 生成一个可信任的随机数源 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(data); } }
代码二
package com.sinosoft.olyvem.common; import java.security.SecureRandom; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; import sun.misc.BASE64Encoder; public class DES ...{ private byte[] desKey; public DES(byte[] desKey) ...{ this.desKey = desKey; } public byte[] doEncrypt(byte[] plainText) throws Exception ...{ // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); byte rawKeyData[] = desKey;/**//* 用某种方法获得密匙数据 */ // 从原始密匙数据创建DESKeySpec对象 DESKeySpec dks = new DESKeySpec(rawKeyData); // 创建一个密匙工厂,然后用它把DESKeySpec转换成 // 一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); SecretKey key = keyFactory.generateSecret(dks); // Cipher对象实际完成加密操作 Cipher cipher = Cipher.getInstance("DES"); // 用密匙初始化Cipher对象 cipher.init(Cipher.ENCRYPT_MODE, key, sr); // 现在,获取数据并加密 byte data[] = plainText;/**//* 用某种方法获取数据 */ // 正式执行加密操作 byte encryptedData[] = cipher.doFinal(data); return encryptedData; } public byte[] doDecrypt(byte[] encryptText) throws Exception ...{ // DES算法要求有一个可信任的随机数源 SecureRandom sr = new SecureRandom(); byte rawKeyData[] = desKey; /**//* 用某种方法获取原始密匙数据 */ // 从原始密匙数据创建一个DESKeySpec对象 DESKeySpec dks = new DESKeySpec(rawKeyData); // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成 // 一个SecretKey对象 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES"); SecretKey key = keyFactory.generateSecret(dks); // Cipher对象实际完成解密操作 Cipher cipher = Cipher.getInstance("DES"); // 用密匙初始化Cipher对象 cipher.init(Cipher.DECRYPT_MODE, key, sr); // 现在,获取数据并解密 byte encryptedData[] = encryptText;/**//* 获得经过加密的数据 */ // 正式执行解密操作 byte decryptedData[] = cipher.doFinal(encryptedData); return decryptedData; } public static void main(String[] args) throws Exception ...{ String key = "FtpXPass"; String value = "olympic"; BASE64Encoder base64Encoder = new BASE64Encoder(); DES desEncrypt = new DES(key.getBytes()); byte[] encryptText = desEncrypt.doEncrypt(value.getBytes()); //System.out.println("doEncrypt - " + toHexString(encryptText)); System.out.println("doEncrypt - " + base64Encoder.encode(encryptText)); byte[] decryptText = desEncrypt.doDecrypt("r9NGYcKAtdo=".getBytes()); System.out.println("doDecrypt - " + new String(decryptText)); //System.out.println("doDecrypt - " + toHexString(decryptText)); } public static String toHexString(byte[] value) ...{ String newString = ""; for (int i = 0; i < value.length; i++) ...{ byte b = value[i]; String str = Integer.toHexString(b); if (str.length() > 2) ...{ str = str.substring(str.length() - 2); } if (str.length() < 2) ...{ str = "0" + str; } newString += str; } return newString.toUpperCase(); } }
以上就是本文关于DES加密解密的代码了,希望对大家学习java有所帮助。
本文向大家介绍java 实现DES 加密解密的示例,包括了java 实现DES 加密解密的示例的使用技巧和注意事项,需要的朋友参考一下 以上就是java 实现DES 加密解密的示例代码的详细内容,更多关于java des加密解密的资料请关注呐喊教程其它相关文章!
问题内容: 我正在尝试使用PHP mcrypt函数解密由Java Triple DES函数加密的密钥,但是没有运气。在下面找到Java代码 我想编写一个与上面的cryptoText Java函数等效的PHP函数。在生成由Java代码生成的用于加密的精确IV值时遇到困难,这是解密所必需的。 问题答案: 这等效于Java代码的PHP(我从The reference的注释中复制了PKCS#5-paddi
密钥: 要加密的消息: 加密消息(UTF-8): 解密函数代码:
本文向大家介绍Python和Java进行DES加密和解密的实例,包括了Python和Java进行DES加密和解密的实例的使用技巧和注意事项,需要的朋友参考一下 DES 为 Data Encryption Standard (数据加密标准)的缩写,是一种常见的对称加密算法。有关对称加密与非对称加密的特点及其应用场景,本文就不描述了,读者可以自行 google 。本文说明如何使用 Java 和 Pyt
说明:DES加密/解密类仅供参考思路,需要接入方具体实现细节及调通 php版DES加密/解密类: <?php /** * Created by PhpStorm. * User: didi * Date: 2017/9/27 * Time: 16:11 */ namespace Library; class DESHelper { //私钥,固定字节长度为8位 priv
本文向大家介绍Java对称加密算法DES实例详解,包括了Java对称加密算法DES实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Java对称加密算法DES。分享给大家供大家参考,具体如下: 一 DES算法概述 1、介绍 DES:Data Encryption Standard 数据加密标准。 2、DES算法参数 二 DES算法Java实现 三 实现效果 jdk des encry