java.security.MessageDigest
public static String toMD5(String plainText) {
MessageDigest messageDigest = null;
try {
messageDigest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
throw new RuntimeException("MD5 error:", e);
}
messageDigest.update(plainText.getBytes());
byte by[] = messageDigest.digest();
StringBuffer buf = new StringBuffer();
int val;
for (int i = 0; i < by.length; i++) {
val = by[i];
if (val < 0) {
val += 256;
} else if (val < 16) {
buf.append("0");
}
buf.append(Integer.toHexString(val));
}
return buf.toString().toUpperCase();
}
/**
* 字符串加密以及解密函数
*
* @param string
* string 原文或者密文
* @param string
* operation 操作(ENCODE | DECODE), 默认为 DECODE
* @param string
* key 密钥
* @param int
* expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效
* @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
*
* @example
*
* a = authcode('abc', 'ENCODE', 'key'); b = authcode( a, 'DECODE', 'key'); //
* b(abc)
*
* a = authcode('abc', 'ENCODE', 'key', 3600); b = authcode('abc', 'DECODE',
* 'key'); // 在一个小时内, b(abc),否则 b 为空
*/
private String uc_authcode(String string, String operation, String key,
int expiry) {
// ckey_length 随机密钥长度 取值 0-32;
// ckey_length 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。
// ckey_length 取值越大,密文变动规律越大,密文变化 = 16 的 ckey_length 次方
// ckey_length 当此值为 0 时,则不产生随机密钥
int ckey_length = 1;
key = md5(key != null ? key : UC_KEY);
String keya = md5(substr(key, 0, 16));
String keyb = md5(substr(key, 16, 16));
// String keyc = ckey_length > 0? ( operation.equals("DECODE") ? substr(
// string, 0, ckey_length): substr(md5(microtime()), - ckey_length)) :
// "";
String keyc = "a";
String cryptkey = keya + md5(keya + keyc);
int key_length = cryptkey.length();
string = operation.equals("DECODE") ? base64_decode(substr(string,
ckey_length)) : sprintf("%010d", expiry > 0 ? expiry : 0)
+ substr(md5(string + keyb), 0, 16) + string;
int string_length = string.length();
StringBuffer result1 = new StringBuffer();
int[] box = new int[256];
for (int i = 0; i < 256; i++) {
box[i] = i;
}
int[] rndkey = new int[256];
for (int i = 0; i <= 255; i++) {
rndkey[i] = (int) cryptkey.charAt(i % key_length);
}
int j = 0;
for (int i = 0; i < 256; i++) {
j = (j + box[i] + rndkey[i]) % 256;
int tmp = box[i];
box[i] = box[j];
box[j] = tmp;
}
j = 0;
int a = 0;
for (int i = 0; i < string_length; i++) {
a = (a + 1) % 256;
j = (j + box[a]) % 256;
int tmp = box[a];
box[a] = box[j];
box[j] = tmp;
result1
.append((char) (((int) string.charAt(i)) ^ (box[(box[a] + box[j]) % 256])));
}
if (operation.equals("DECODE")) {
String result = result1.substring(0, result1.length());
if ((Integer.parseInt(substr(result.toString(), 0, 10)) == 0 || Long
.parseLong(substr(result.toString(), 0, 10)) > 0)
&& substr(result.toString(), 10, 16).equals(
substr(md5(substr(result.toString(), 26) + keyb),
0, 16))) {
return substr(result.toString(), 26);
} else {
return "";
}
} else {
return keyc + base64_encode(result1.toString()).replaceAll("=", "");
}
}
MessageDigest messageDigest = null;
try {
messageDigest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e) {
// TODO Auto-generated catch block
throw new RuntimeException("MD5 error:", e);
}
messageDigest.update(plainText.getBytes());
byte by[] = messageDigest.digest();
StringBuffer buf = new StringBuffer();
int val;
for (int i = 0; i < by.length; i++) {
val = by[i];
if (val < 0) {
val += 256;
} else if (val < 16) {
buf.append("0");
}
buf.append(Integer.toHexString(val));
}
return buf.toString().toUpperCase();
}
* 字符串加密以及解密函数
*
* @param string
* string 原文或者密文
* @param string
* operation 操作(ENCODE | DECODE), 默认为 DECODE
* @param string
* key 密钥
* @param int
* expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效
* @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
*
* @example
*
* a = authcode('abc', 'ENCODE', 'key'); b = authcode( a, 'DECODE', 'key'); //
* b(abc)
*
* a = authcode('abc', 'ENCODE', 'key', 3600); b = authcode('abc', 'DECODE',
* 'key'); // 在一个小时内, b(abc),否则 b 为空
*/
private String uc_authcode(String string, String operation, String key,
int expiry) {
// ckey_length 随机密钥长度 取值 0-32;
// ckey_length 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。
// ckey_length 取值越大,密文变动规律越大,密文变化 = 16 的 ckey_length 次方
// ckey_length 当此值为 0 时,则不产生随机密钥
int ckey_length = 1;
key = md5(key != null ? key : UC_KEY);
String keya = md5(substr(key, 0, 16));
String keyb = md5(substr(key, 16, 16));
// String keyc = ckey_length > 0? ( operation.equals("DECODE") ? substr(
// string, 0, ckey_length): substr(md5(microtime()), - ckey_length)) :
// "";
String keyc = "a";
String cryptkey = keya + md5(keya + keyc);
int key_length = cryptkey.length();
string = operation.equals("DECODE") ? base64_decode(substr(string,
ckey_length)) : sprintf("%010d", expiry > 0 ? expiry : 0)
+ substr(md5(string + keyb), 0, 16) + string;
int string_length = string.length();
StringBuffer result1 = new StringBuffer();
int[] box = new int[256];
for (int i = 0; i < 256; i++) {
box[i] = i;
}
int[] rndkey = new int[256];
for (int i = 0; i <= 255; i++) {
rndkey[i] = (int) cryptkey.charAt(i % key_length);
}
int j = 0;
for (int i = 0; i < 256; i++) {
j = (j + box[i] + rndkey[i]) % 256;
int tmp = box[i];
box[i] = box[j];
box[j] = tmp;
}
j = 0;
int a = 0;
for (int i = 0; i < string_length; i++) {
a = (a + 1) % 256;
j = (j + box[a]) % 256;
int tmp = box[a];
box[a] = box[j];
box[j] = tmp;
result1
.append((char) (((int) string.charAt(i)) ^ (box[(box[a] + box[j]) % 256])));
}
if (operation.equals("DECODE")) {
String result = result1.substring(0, result1.length());
if ((Integer.parseInt(substr(result.toString(), 0, 10)) == 0 || Long
.parseLong(substr(result.toString(), 0, 10)) > 0)
&& substr(result.toString(), 10, 16).equals(
substr(md5(substr(result.toString(), 26) + keyb),
0, 16))) {
return substr(result.toString(), 26);
} else {
return "";
}
} else {
return keyc + base64_encode(result1.toString()).replaceAll("=", "");
}
}
本文介绍了一个使用Java实现的MD5加密方法及一个用于字符串加密和解密的函数。MD5方法能够将输入的纯文本转换成MD5散列值,而加密解密函数则利用了MD5、Base64等技术实现数据的安全处理。
1040

被折叠的 条评论
为什么被折叠?



