需要注意的是,不同的编码方式可能会导致相同的字符串在计算消息摘要时得到不同的结果。因此,在使用Java的MD5算法时,你应该确保输入字符串的编码方式与你预期的一致。
总之,在Java中使用MD5算法时,输入字符串的格式是有影响的,你需要注意字符串的格式以及编码方式,以确保得到正确的结果。
回答不易,望请采纳
这是我以前做的一个小项目时用到md5写的
import java.security.MessageDigest
import java.security.NoSuchAlgorithmException
//将用户密码进行md5加密 并返回加密后的32位十六进制密码
public class MD5Util {
public static String md5(String password) {
try {
// 获取md5对象
MessageDigest md = MessageDigest.getInstance("md5")
// 获取加密后的密码并返回十进制字节数组
byte[] bytes = md.digest(password.getBytes())
// 遍历数组得到每个十进制数并转换成十六进制
StringBuffer sb = new StringBuffer()
for (byte b : bytes) {
// 把每个数转成十六进制 存进字符中
sb.append(toHex(b))
}
String finish = sb.toString()
return finish
} catch (NoSuchAlgorithmException e) {
e.printStackTrace()
throw new RuntimeException(e)
}
}
// 十进制转十六进制方法
private static String toHex(byte b) {
int target = 0
if (b <0) {
target = 255 + b
} else {
target = b
}
int first = target / 16
int second = target % 16
return Hex[first] + Hex[second]
}
static String[] Hex = { "0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
"a", "b", "c", "d", "e", "f" }
/*public static void main(String[] args) {
String a = MD5Util.md5("1234")
System.out.println(a)
}*/
}
JDK里面有一个java.security.MessageDigest类,这个类就是用来加密的。
加密代码如下:
String token = System.currentTimeMillis()+new Random().nextInt()+""try {
MessageDigest md = MessageDigest.getInstance("MD5")
byte[] md5 = md.digest(token.getBytes())
} catch (Exception e) {
throw new RuntimeException(e)
}
这个byte类型的数组就是使用MD5加密后的结果