数据校验用的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(pa