按照用java自定义写的MD5规则用ASP.NET生成相同的加密串
下面这个java程序是自定义MD5规则生成一个加密串,我想用ASP.NET实现和它结果一样的加密串,如何处理
package test;
import java.util.Date;
import java.text.SimpleDateFormat;
import java.security.MessageDigest;
public class im {
private static String strDefaultKey = "njtc21";
/**
* 生成规则:以当前日期+默认字串+用户ID(如:20090703njtc21000003)生成md5散列值,并取出第9到第24位。
* @return String
*/
private static String getKey(String username) {
String date = formatDate(new Date(), "yyyyMMdd");
String key = getMD5( (date + strDefaultKey + username).getBytes());
return key.substring(8, 24);
}
/**
* 格式化日期
* @param value Date
* @param pattern String
* @return String
*/
private static String formatDate(Date value, String pattern) {
SimpleDateFormat sdf = new SimpleDateFormat(pattern);
return value == null ? "" : sdf.format(value);
}
/**
* 生成md5散列值
* @param source byte[]
* @return String
*/
private static String getMD5(byte[] source) {
String s = null;
char hexDigits[] = { // 用来将字节转换成 16 进制表示的字符
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
try {
java.security.MessageDigest md = java.security.MessageDigest.getInstance("MD5");
md.update(source);
byte tmp[] = md.digest(); // MD5 的计算结果是一个 128 位的长整数,
// 用字节表示就是 16 个字节
char str[] = new char[16 * 2]; // 每个字节用 16 进制表示的话,使用两个字符,
// 所以表示成 16 进制需要 32 个字符
int k = 0; // 表示转换结果中对应的字符位置
for (int i = 0; i < 16; i++) { // 从第一个字节开始,对 MD5 的每一个字节
// 转换成 16 进制字符的转换
byte byte0 = tmp[i]; // 取第 i 个字节
str[k++] = hexDigits[byte0 >>> 4 & 0xf]; // 取字节中高 4 位的数字转换,
// >>> 为逻辑右移,将符号位一起右移
str[k++] = hexDigits[byte0 & 0xf]; // 取字节中低 4 位的数字转换
}
s = new String(str); // 换后的结果转换为字符串
}
catch (Exception e) {
e.printStackTrace();
}
return s;
}
public static void main(String[] args) {
im t = new im();
System.out.println("" + t.getMD5("000003".getBytes()));
System.out.println("" + t.getKey("000003"));
}
}