MD5加密

来源:互联网 发布:卓易云软件下载 编辑:程序博客网 时间:2024/06/03 21:15

对于明文转“暗文”的逻辑应该放在业务层去做。

对于用户输入的密码转为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的商,例如:14int d1 = n / 16;//n除16的商的余数,例如:1int 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);}}



0 0
原创粉丝点击