可以利用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("加密"))
}
}
&这个是位运算“且”sb.append(hexChar[(b[i] &0xf0) >>>4])
//(b[i] &0xf0)这个意思就是取b[i]的后4位
“>>>无符号右移”
sb.append(hexChar[b[i] &0x0f])
//这个意思就是取b[i]的前4位
我使用了部分取值的方式来提高MD5的计算速度,这样的时候,时间主要耗费在了IO中。如果是100K(换成500K也并没有提高执行的速度)取一个字符计算大约10秒以内。但是如果全部读取可能要60秒或者更多。对于大文件建议使用一些文件相关信息和部分文件内容做MD5.比如用文件长度和一定间隔取一些字节。欢迎分享,转载请注明来源:内存溢出
评论列表(0条)