MD5加盐的一个简单算法

MD5加盐的一个简单算法一般使用的加盐 md5 Password UserName 即将用户名和密码字符串相加再 MD5 这样的 MD5 摘要基本上不可反查 但有时候用户名可能会发生变化 发生变化后密码即不可用了 验证密码实际上就是再次计算摘要的过程 因此我们做了一个非常简单的加盐算法 每次保存密码到数据库时 都生成一个随机 16 位数字 将这 16 位数字和密码相加再求 MD5 摘要 然后在摘要中再将这 16 位数字按规则掺入形成

一般使用的加盐:
md5(Password+UserName),即将用户名和密码字符串相加再MD5,这样的MD5摘要基本上不可反查。
但有时候用户名可能会发生变化,发生变化后密码即不可用了(验证密码实际上就是再次计算摘要的过程)。




因此我们做了一个非常简单的加盐算法,每次保存密码到数据库时,都生成一个随机16位数字,将这16位数字和密码相加再求MD5摘要,然后在摘要中再将这16位数字按规则掺入形成一个48位的字符串。

package com.md5.demo; import java.security.MessageDigest; import java.util.Random; import org.apache.commons.codec.binary.Hex; / * MD5加盐加密 */ public class PasswordUtil { / * 生成含有随机盐的密码 */ public static String generate(String password) { Random r = new Random(); StringBuilder sb = new StringBuilder(16); sb.append(r.nextInt()).append(r.nextInt()); int len = sb.length(); if (len < 16) { for (int i = 0; i < 16 - len; i++) { sb.append("0"); } } String salt = sb.toString(); password = md5Hex(password + salt); char[] cs = new char[48]; for (int i = 0; i < 48; i += 3) { cs[i] = password.charAt(i / 3 * 2); char c = salt.charAt(i / 3); cs[i + 1] = c; cs[i + 2] = password.charAt(i / 3 * 2 + 1); } return new String(cs); } / * 校验密码是否正确 */ public static boolean verify(String password, String md5) { char[] cs1 = new char[32]; char[] cs2 = new char[16]; for (int i = 0; i < 48; i += 3) { cs1[i / 3 * 2] = md5.charAt(i); cs1[i / 3 * 2 + 1] = md5.charAt(i + 2); cs2[i / 3] = md5.charAt(i + 1); } String salt = new String(cs2); return md5Hex(password + salt).equals(new String(cs1)); } / * 获取十六进制字符串形式的MD5摘要 */ public static String md5Hex(String src) { try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] bs = md5.digest(src.getBytes()); return new String(new Hex().encode(bs)); } catch (Exception e) { return null; } } } 

测试:

 public static void main(String[] args) { // 加密+加盐 String password1 = generate("admin"); System.out.println("结果:" + password1 + " 长度:"+ password1.length()); // 解码 System.out.println(verify("admin", password1)); // 加密+加盐 String password2= generate("admin"); System.out.println("结果:" + password2 + " 长度:"+ password2.length()); // 解码 System.out.println(verify("admin", password2)); } 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215354.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午2:06
下一篇 2026年3月18日 下午2:07


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号