可以利用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("加密"))
}
}
Java中使用MD5算法计算消息摘要时,输入字符串的格式是有影响的。为了得到正确的结果,你需要确保输入字符串的格式符合一定的要求。比如,如果你使用了多余的空格或其他非法字符,那么你得到的消息摘要可能会与预期不符。需要注意的是,不同的编码方式可能会导致相同的字符串在计算消息摘要时得到不同的结果。因此,在使用Java的MD5算法时,你应该确保输入字符串的编码方式与你预期的一致。
总之,在Java中使用MD5算法时,输入字符串的格式是有影响的,你需要注意字符串的格式以及编码方式,以确保得到正确的结果。
回答不易,望请采纳