[code="java"]
/**
* 加密;
*/
public static String encrypt(String value){
String key = getLimStr("ABCDEHIJKLMNOPQRSTUVWSVZ123456789",24);
String encryptString = null;
if(value!=null){
encryptString = desEncrypt(key, value);
}
return encryptString;
}
/**
* 解密;
*/
public static String decrypt(String value){
String key = getLimStr("ABCDEHIJKLMNOPQRSTUVWSVZ123456789",24);
String decryptString = null;
if(value!=null){
decryptString = desDecrypt(key, value);
}
return decryptString;
}
/**
* 信息摘要是安全的单向哈希函数,它接收任意大小的数据,输出固定长度的哈希值。
* md5算法一般是明文和另外一个字符串key相加再加密
* 输出固定32位
*/
@SuppressWarnings("unused")
private static String md5Encypt(String key,String src){
MessageDigest alg;
try {
alg = MessageDigest.getInstance("MD5");
alg.update((key+src).getBytes());
return byteArrayToHexString(alg.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
}
/**
* 3DES加密
* @param key密钥字符串 长度为24字节
* @param src明文字符串
* @return 密文字符串
*/
private static String desEncrypt(String key, String src){
byte[] b=desEncrypt(genDESKey(key.getBytes()), src.getBytes());
return byteArrayToHexString(b);
}
/**
* 3DES解密
* @param key 密钥字符串
* @param crypt密文字符串
* @return 明文字符串
*/
private static String desDecrypt(String key, String crypt){
byte[] b=desDecrypt(genDESKey(key.getBytes()), hexStringToBytes(crypt));
return new String(b);
}
/**
* 3DES加密(byte[]).
*/
private static byte[] desEncrypt(SecretKey key, byte[] src){
try {
Cipher cipher = Cipher.getInstance("DESede");
cipher.init(Cipher.ENCRYPT_MODE, key);
return cipher.doFinal(src);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* 加密;
*/
public static String encrypt(String value){
String key = getLimStr("ABCDEHIJKLMNOPQRSTUVWSVZ123456789",24);
String encryptString = null;
if(value!=null){
encryptString = desEncrypt(key, value);
}
return encryptString;
}
/**
* 解密;
*/
public static String decrypt(String value){
String key = getLimStr("ABCDEHIJKLMNOPQRSTUVWSVZ123456789",24);
String decryptString = null;
if(value!=null){
decryptString = desDecrypt(key, value);
}
return decryptString;
}
/**
* 信息摘要是安全的单向哈希函数,它接收任意大小的数据,输出固定长度的哈希值。
* md5算法一般是明文和另外一个字符串key相加再加密
* 输出固定32位
*/
@SuppressWarnings("unused")
private static String md5Encypt(String key,String src){
MessageDigest alg;
try {
alg = MessageDigest.getInstance("MD5");
alg.update((key+src).getBytes());
return byteArrayToHexString(alg.digest());
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
}
/**
* 3DES加密
* @param key密钥字符串 长度为24字节
* @param src明文字符串
* @return 密文字符串
*/
private static String desEncrypt(String key, String src){
byte[] b=desEncrypt(genDESKey(key.getBytes()), src.getBytes());
return byteArrayToHexString(b);
}
/**
* 3DES解密
* @param key 密钥字符串
* @param crypt密文字符串
* @return 明文字符串
*/
private static String desDecrypt(String key, String crypt){
byte[] b=desDecrypt(genDESKey(key.getBytes()), hexStringToBytes(crypt));
return new String(b);
}
/**
* 3DES加密(byte[]).
*/
private static byte[] desEncrypt(SecretKey key, byte[] src){
try {
Cipher cipher = Cipher.getInstance("DESede");
cipher.init(Cipher.ENCRYPT_MODE, key);
return cipher.doFinal(src);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}