需要注意的是,不同的编码方式可能会导致相同的字符串在计算消息摘要时得到不同的结果。因此,在使用Java的MD5算法时,你应该确保输入字符串的编码方式与你预期的一致。
总之,在Java中使用MD5算法时,输入字符串的格式是有影响的,你需要注意字符串的格式以及编码方式,以确保得到正确的结果。
回答不易,望请采纳
可以利用JDK自带的MD5来加密。
public class MD5Util {public final static String MD5(String s) {
char hexDigits[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'}
try {
byte[] btInput = s.getBytes()
// 获得MD5摘要算法的 MessageDigest 对象
MessageDigest mdInst = MessageDigest.getInstance("MD5")
// 使用指定的字节更新摘要
mdInst.update(btInput)
// 获得密文
byte[] md = mdInst.digest()
// 把密文转换成十六进制的字符串形式
int j = md.length
char str[] = new char[j * 2]
int k = 0
for (int i = 0 i < j i++) {
byte byte0 = md[i]
str[k++] = hexDigits[byte0 >>> 4 & 0xf]
str[k++] = hexDigits[byte0 & 0xf]
}
return new String(str)
} catch (Exception e) {
e.printStackTrace()
return null
}
}
public static void main(String[] args) {
System.out.println(MD5Util.MD5("20121221"))
System.out.println(MD5Util.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)
}*/
}