private static final byte[] PASSWORD_CRYPT_KEY = new byte[] { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h' };
private final static String DES = "DES";
public String encrypt(String pureStr) {
if (pureStr == null || pureStr.length() == 0) {
return null;
}
byte[] bytes = encrypt(pureStr.getBytes(), PASSWORD_CRYPT_KEY);
if (bytes == null) {
return null;
}
return encodeBase64(bytes);
}
/**
* 加密
* @param src - 数据源
* @param key - 密钥,长度必须是8的倍数
* @return 返回加密后的数据
* @throws Exception
* - 异常处理
*/
private static byte[] encrypt(byte[] src, byte[] key) {
try {
// 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);
// 现在,获取数据并加密
// 正式执行加密操作
byte[] bytes = cipher.doFinal(src);
return bytes;
} catch (Exception ex) {
return null;
}
}
private final static String encodeBase64(byte[] bytes) {
if (bytes == null || bytes.length == 0) {
return "";
}
BASE64Encoder encoder = new BASE64Encoder();
return encoder.encode(bytes);
}