数据校验用的MD5:
def getMessageMd5(string: String): String = {
try {
val mD5 = MessageDigest.getInstance("MD5")
mD5.update(string.getBytes())
BigInt(1, mD5.digest()).toString(16)
// 也是stackoverflow 上给出的解决方法,但是不好使,报错了
//String.format("%032x",BigInt(1, mD5.digest()).toString(16))
}
catch {
case e: Exception => e.printStackTrace()
""
}
}
问题:
生成的md5值是31位(前面没有补0)是java.security.MessageDigest 的BUG
原因:
为什么会少一位,原来byte数组中有的值可能小于16,所以转换成16进制的时候用1位就可以表示了。这个时候我们应该在前面加上个0
Java 解决方案:
public static void main(String[] args) throws Exception
{
MessageDigest md5 = MessageDigest.getInstance("MD5");
String password = "wodemima";
byte[] bytes = md5.digest(password.getBytes());
String result = "";
for(byte b : bytes)
{
String temp = Integer.toHexString(b & 0xff);
if(temp.length() == 1)
{
temp = "0" + temp;
}
result = result + temp;
}
System.out.println(result);
}
利用可变变量来实现循环显然不是我们scala的风范:
所以直接用现成的函数:
org.apache.commons.codec.digest.DigestUtils.md5Hex()
正解:
def getMessageMd5(string: String): String = {
try {
//正解
org.apache.commons.codec.digest.DigestUtils.md5Hex(string)
}
catch {
case e: Exception => e.printStackTrace()
""
}
}
博客讨论了在Java中使用`java.security.MessageDigest`生成MD5哈希值时遇到的问题,即生成的哈希值为31位而非标准的32位,原因是部分byte值小于16导致16进制表示时缺少前导0。文章提供了Java的解决方法,并指出在Scala中可以使用现成的函数来避免此类问题。

1602

被折叠的 条评论
为什么被折叠?



