MD5Util —— MD5加密个人笔记

可以直接作为一个工具类,传入一个字符串,则返回一个加密后的字符串

public class MD5Util {
    public static String md5(String pas) {
         //pas为空时返回值为:becf72503940cf7ff0df9c224118e8f6
         //加盐处理
        String pass = pas + "mobilesafe"; 
        try {
            //1指定加密算法类型
            MessageDigest digest = MessageDigest.getInstance("MD5");
            //2将加密的字符串中专成byte类型数组,然后进行hash过程
            byte[] bs = digest.digest(pass.getBytes());
            //3进行循环遍历bs,然后让其生成32位字符串,固定写法
            //4拼接成字符串过程
            StringBuffer stringBuffer=new StringBuffer();
            for (byte b : bs) {
                int i = b & 0xff;
            //byte类型的数字要&0xff再赋值给int类型,
            //其本质原因就是想保持二进制补码的一致性。
            //int 类型的i需要转换为16进制字符
                String hexString = Integer.toHexString(i);
                if(hexString.length()<2){
                    hexString+="0";
                }
                stringBuffer.append(hexString);
            }
            //测试
            System.out.println("加密结果"+stringBuffer.toString());
        return stringBuffer.toString();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return "";
    }
}

猜你喜欢

转载自blog.csdn.net/angelar_baby/article/details/84971459
今日推荐