<span style="font-family: Menlo; font-size: 12pt; background-color: rgb(255, 255, 255);"></span><pre name="code" class="java">//采用MD5算法加密,不可逆
public String md5(String originalStr) {
StringBuffer sb = new StringBuffer(); //采用线程安全的stringBuffer
String res = null;
Log.i(TAG, "using md5 encryption");
try {
MessageDigest md5 = MessageDigest.getInstance("md5");
byte[] b = md5.digest(originalStr.getBytes());
//byte 的范围是-128~127
//之所以不采用new String(b),是因为String的构造体把负数的byte转换成int时,前面的高位都填充1,导致错误
for (byte ba : b) {
String t = Integer.toHexString(ba & 0xff);
if (t.length() == 1) { //如果转换成16进制,只占一位,补齐到2位,固定位数方便服务器核对
sb.append("0");
}
sb.append(t);
}
res = sb.toString();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} finally {
return res;
}
}
关于md5加密的认识
最新推荐文章于 2021-07-26 21:50:18 发布