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 "";
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的Java代码示例,展示如何使用MD5Util对字符串进行加密: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class MD5Util { // 将字符串进行MD5加密 public static String md5(String str) { try { // 获取MessageDigest实例,指定加密算法为MD5 MessageDigest md = MessageDigest.getInstance("MD5"); // 更新摘要内容 md.update(str.getBytes()); // 获取加密结果,转换为16进制字符串 byte[] digest = md.digest(); StringBuilder sb = new StringBuilder(); for (byte b : digest) { // 将每个字节转换为两位16进制数,不足补0 String hex = Integer.toHexString(b & 0xff); if (hex.length() == 1) { sb.append("0"); } sb.append(hex); } return sb.toString(); } catch (NoSuchAlgorithmException e) { // 异常处理 e.printStackTrace(); return null; } } public static void main(String[] args) { // 测试MD5加密 String password = "123456"; String md5Password = md5(password); System.out.println(md5Password); } } ``` 在上面的代码中,我们首先通过`MessageDigest.getInstance("MD5")`获取MessageDigest实例,指定加密算法为MD5。然后,我们通过`md.update(str.getBytes())`将字符串的字节数组更新到摘要中,接着通过`md.digest()`获取加密结果的字节数组,最后将字节数组转换为16进制字符串返回。 在实际应用中,我们通常会将用户输入的密码进行MD5加密后再存储到数据库中,以保障用户的密码安全。在用户登录时,我们需要将用户输入的密码再次进行MD5加密,然后与数据库中存储的MD5摘要进行比对,以验证用户身份。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值