您的位置:首页 > 其它

关于md5加密的认识

2015-08-10 21:00 435 查看
<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;
    }
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: