下面是一段.textblog中的密码加密代码,现在数据库中已经大量存在这些加密后的密码了,公司要求用JAVA再做一个入口,如果用户从JAVA口进入,也要判断用户名与密码是不是一致,但问题是那个是C#的专用加密算法,用JAVA如何实现呢?请教大家了!
代码如下: strText = strText.ToLower();
Byte[] clearBytes = new UnicodeEncoding().GetBytes(strText);
Byte[] hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);
return BitConverter.ToString(hashedBytes);
代码如下: strText = strText.ToLower();
Byte[] clearBytes = new UnicodeEncoding().GetBytes(strText);
Byte[] hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);
return BitConverter.ToString(hashedBytes);
import java.security.MessageDigest;/**
* @author closewbq
* @version 1.0
* 对密码进行加密和验证
*/
public class MD5Util { /**
* 16进制下的映射数组
*/
private final static String[] hexDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" }; /**
* 将密码进行加密处理
* @param password
* @return 加密后的字符串
*/
public static String getPassByMD5(String password) {
return stringByMD5(password);
} /**
* 验证登录密码是否正确
* @param password 加密后的密码
* @param loginPassword 登录的密码
* @return 验证结果,TRUE:正确 FALSE:错误
*/
public static boolean validatePassword(String password, String loginPassword) {
if (password.equals(stringByMD5(loginPassword))) {
return true;
} else {
return false;
}
} /**
* 对字符串进行加密处理
* @param strString
* @return 加密后的字符串
*/
private static String stringByMD5(String strString) {
if (strString != null) {
try {
//创建MD5算法的信息摘要
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] results = md.digest(strString.getBytes());
//将得到的字节数组变成字符串返回
String resultString = byteArrayToHexString(results);
return resultString.toUpperCase();
} catch (Exception ex) {
ex.printStackTrace();
}
}
return null;
} /**
* 转换字节数组为十六进制字符串
* @param 字节数组
* @return 十六进制字符串
*/
private static String byteArrayToHexString(byte[] results) {
StringBuffer resultSb = new StringBuffer();
for (int i = 0; i < results.length; i++) {
resultSb.append(byteToHexString(results[i]));
}
return resultSb.toString();
}
/**
* 将一个字节转化成十六进制形式的字符串
* @param b
* @return 十六进制形式的字符
*/
private static String byteToHexString(byte b) {
int n = b;
if (n < 0)
n = 256 + n;
int d1 = n / 16;
int d2 = n % 16;
return hexDigits[d1] + hexDigits[d2];
}
}
.net进行加密我们一般也不这么写呀,
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str,"MD5");
三楼正解,在.net中md5加密一句话就OK,楼主的方法就是重复造轮子
1234
用C#算法加密完:0F-03-75-84-C9-9E-7F-D4-F4-F8-C5-95-50-F8-F5-07
md5是:81dc9bdb52d04dc20036dbd8313ed055哪位用JAVA把1234加完MD5是上面c# 那样,我二百分献上,不够再开一帖子
MessgeDigest是专门用来加密的类!public String toMD5(String input){
MessageDigest digest = MessageDigest.getInstance("MD5");
byte[] res = digest.digest(input.getBytes());
return toHex(res);
}
private String toHex(byte[] input){
StringBuffer buffer = new StringBuffer();
for (int i = 0; i < input.length; i++) {
int low = input[i] & 0x0f;
int high = (input[i] >>> 4) & 0x0f;
buffer.append(Character.forDigit(high, 16));
buffer.append(Character.forDigit(low, 16));
}
return buffer.toString();
}
C#写个webservice,java程序来调用就好了。