对于明文转“暗文”的逻辑应该放在业务层去做。
对于用户输入的密码转为MD5基本代码如下所示:通过“暗文”再与数据库里面的暗文匹配,匹配成功就说明密码正确。
package cn.ydl.md5; import java.security.MessageDigest; /** * MD5工具类 * 只有加密,无解密 */ public final class Md5Util { private Md5Util(){} /** * 将明文密码变成MD5密码 * @param password 明文密码 例如:123456 * @return MD5密码 例如:e10adc3949ba59abbe56e057f20f883e * MessageDigest只负责将String转成byte[]即完, * 程序员需要将byte[]转成32位16进制字符串 */ public String encodeByMd5(String password) throws Exception{ //创建MD5加密对象 MessageDigest md5 = MessageDigest.getInstance("MD5"); //按照MD5算法,将字符串转成byte[] byte[] byteArary = md5.digest(password.getBytes());//public byte[] digest(byte[] input) //将byte[]转成16进制字符串 return byteArrayToHexString(byteArary); } /** * 将byte[]转成16进制字符串 */ private String byteArrayToHexString(byte[] byteArray) throws Exception{ StringBuffer sb = new StringBuffer(); //迭代 for(byte b : byteArray){ //将byte转入16进制字符串 String hexString = byteToHexString(b); //将16进制字符串放入StringBuffer对象中拼接 sb.append(hexString); } return sb.toString(); } /** * 将byte转成16进制字符串算法 * @param b 数字,例如:-31 在byte范围下等于 225 * @return 16进制字符串,例如e1 */ private String byteToHexString(byte b) throws Exception{ //用int类型接收byte类型值 int n = b; //如果是负数 if(n < 0){ //将负数在byte范围下转成正数 n = 256 + n; } //n除16的商,例如:14 int d1 = n / 16; //n除16的商的余数,例如:1 int d2 = n % 16; //通过下标访问数组中的值 return hex[d1] + hex[d2]; } //定义一个数组,里面装的都是16进制字符串 private String[] hex = {"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 password = "000111"; Md5Util test = new Md5Util(); //将明文密码变成MD5密码 String passwordMD5 = test.encodeByMd5(password); //显示 System.out.println(password); System.out.println(passwordMD5); } }