public class DesUtils { private final static String KEY = "hgcard6612"; private final static String TRANSFORMATION = "DES/CBC/PKCS5Padding";//DES是加密方式 CBC是工作模式 PKCS5Padding是填充模式 private final static String IVPARAMETERSPEC = "01020304";初始化向量参数,AES 为16bytes. DES 为8bytes. private final static String ALGORITHM = "DES";//DES是加密方式 // 对密钥进行处理 private static Key getRawKey(String key) throws Exception { DESKeySpec dks = new DESKeySpec(key.getBytes()); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM); return keyFactory.generateSecret(dks); } /** * DES算法,加密 * * @param data 待加密字符串 * @return 加密后的字节数组,一般结合Base64编码使用 */ public static String encode(String data) { return encode(data.getBytes()); } /** * DES算法,加密 * * @param data 待加密字符串 * @return 加密后的字节数组,一般结合Base64编码使用 */ public static String encode(byte[] data) { try { Cipher cipher = Cipher.getInstance(TRANSFORMATION); IvParameterSpec iv = new IvParameterSpec(IVPARAMETERSPEC.getBytes()); cipher.init(Cipher.ENCRYPT_MODE, getRawKey(KEY), iv); byte[] bytes = cipher.doFinal(data); return Base64.encodeToString(bytes, Base64.DEFAULT); } catch (Exception e) { return null; } } /** * 获取编码后的值 * * @param data * @return */ public static String decode(String data) { return decode(Base64.decode(data, Base64.DEFAULT)); } /** * DES算法,解密 * * @param data 待解密字符串 * @return 解密后的字节数组 */ public static String decode(byte[] data) { try { Cipher cipher = Cipher.getInstance(TRANSFORMATION); IvParameterSpec iv = new IvParameterSpec(IVPARAMETERSPEC.getBytes()); cipher.init(Cipher.DECRYPT_MODE, getRawKey(KEY), iv); byte[] original = cipher.doFinal(data); String originalString = new String(original); return originalString; } catch (Exception e) { return null; } } }
des加密
最新推荐文章于 2024-07-18 08:56:36 发布