方法----MessageDigest和DigestUtils加密算法

总结:使用DigestUtils的方法加密的结果与messageDigest的方法加密结果一致,可使用DigestUtils替换MessageDigest 可省掉部分代码
package com.action;

import java.security.MessageDigest;

import org.apache.commons.codec.digest.DigestUtils;

public class Hello {
    
    private static final char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
    
    public static void main(String[] args) throws Exception {
        String testStr = "baichuanyu12";
        
        //使用DigestUtils进行md5加密  需要引入 commons-codec.jar
        String md5Result = DigestUtils.md5Hex(testStr.getBytes());
        System.out.println(md5Result);
        //使用DigestUtils进行sha1加密
        String sha1Result = DigestUtils.shaHex(testStr.getBytes());
        System.out.println(sha1Result);
        
        //使用MessageDigest进行MD5加密
        MessageDigest md = MessageDigest.getInstance("MD5");
        md.update(testStr.getBytes());
        String md5 = getFormattedText(md.digest());
        System.out.println(md5);
        //使用MessageDigest进行SHA1加密
        MessageDigest md_sha = MessageDigest.getInstance("SHA-1");
        md_sha.update(testStr.getBytes());
        String sha1 = getFormattedText(md_sha.digest());
        System.out.println(sha1);
    }

    // 加密算法 把密文转成16进制的字符串形式
    public static String getFormattedText(byte[] bytes) {
        int len = bytes.length;
        StringBuilder buf = new StringBuilder(len * 2);
        for (int j = 0; j < len; j++) {
            buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);
            buf.append(HEX_DIGITS[bytes[j] & 0x0f]);
        }
        return buf.toString();
    }
}

转载于:https://www.cnblogs.com/zt007/p/5945733.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值