博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java实现MD5加密解密类
阅读量:7181 次
发布时间:2019-06-29

本文共 4947 字,大约阅读时间需要 16 分钟。

Java实现MD5加密以及解密类,附带测试类,具体见代码。

MD5加密解密类——MyMD5Util,代码如下

package com.zyg.security.md5;import java.io.UnsupportedEncodingException;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;import java.security.SecureRandom;import java.util.Arrays;public class MyMD5Util {  private static final String HEX_NUMS_STR="0123456789ABCDEF"; private static final Integer SALT_LENGTH = 12;  /**   * 将16进制字符串转换成字节数组   * @param hex   * @return   */ public static byte[] hexStringToByte(String hex) {  int len = (hex.length() / 2);  byte[] result = new byte[len];  char[] hexChars = hex.toCharArray();  for (int i = 0; i < len; i++) {   int pos = i * 2;   result[i] = (byte) (HEX_NUMS_STR.indexOf(hexChars[pos]) << 4        | HEX_NUMS_STR.indexOf(hexChars[pos + 1]));  }  return result; }  /**  * 将指定byte数组转换成16进制字符串  * @param b  * @return  */ public static String byteToHexString(byte[] b) {  StringBuffer hexString = new StringBuffer();  for (int i = 0; i < b.length; i++) {   String hex = Integer.toHexString(b[i] & 0xFF);   if (hex.length() == 1) {    hex = '0' + hex;   }   hexString.append(hex.toUpperCase());  }  return hexString.toString(); }  /**  * 验证口令是否合法  * @param password  * @param passwordInDb  * @return  * @throws NoSuchAlgorithmException  * @throws UnsupportedEncodingException  */ public static boolean validPassword(String password, String passwordInDb)   throws NoSuchAlgorithmException, UnsupportedEncodingException {  //将16进制字符串格式口令转换成字节数组  byte[] pwdInDb = hexStringToByte(passwordInDb);  //声明盐变量  byte[] salt = new byte[SALT_LENGTH];  //将盐从数据库中保存的口令字节数组中提取出来  System.arraycopy(pwdInDb, 0, salt, 0, SALT_LENGTH);  //创建消息摘要对象  MessageDigest md = MessageDigest.getInstance("MD5");  //将盐数据传入消息摘要对象  md.update(salt);  //将口令的数据传给消息摘要对象  md.update(password.getBytes("UTF-8"));  //生成输入口令的消息摘要  byte[] digest = md.digest();  //声明一个保存数据库中口令消息摘要的变量  byte[] digestInDb = new byte[pwdInDb.length - SALT_LENGTH];  //取得数据库中口令的消息摘要  System.arraycopy(pwdInDb, SALT_LENGTH, digestInDb, 0, digestInDb.length);  //比较根据输入口令生成的消息摘要和数据库中消息摘要是否相同  if (Arrays.equals(digest, digestInDb)) {   //口令正确返回口令匹配消息   return true;  } else {   //口令不正确返回口令不匹配消息   return false;  } } /**  * 获得加密后的16进制形式口令  * @param password  * @return  * @throws NoSuchAlgorithmException  * @throws UnsupportedEncodingException  */ public static String getEncryptedPwd(String password)   throws NoSuchAlgorithmException, UnsupportedEncodingException {  //声明加密后的口令数组变量  byte[] pwd = null;  //随机数生成器  SecureRandom random = new SecureRandom();  //声明盐数组变量  byte[] salt = new byte[SALT_LENGTH];  //将随机数放入盐变量中  random.nextBytes(salt);  //声明消息摘要对象  MessageDigest md = null;  //创建消息摘要  md = MessageDigest.getInstance("MD5");  //将盐数据传入消息摘要对象  md.update(salt);  //将口令的数据传给消息摘要对象  md.update(password.getBytes("UTF-8"));  //获得消息摘要的字节数组  byte[] digest = md.digest();  //因为要在口令的字节数组中存放盐,所以加上盐的字节长度  pwd = new byte[digest.length + SALT_LENGTH];  //将盐的字节拷贝到生成的加密口令字节数组的前12个字节,以便在验证口令时取出盐  System.arraycopy(salt, 0, pwd, 0, SALT_LENGTH);  //将消息摘要拷贝到加密口令字节数组从第13个字节开始的字节  System.arraycopy(digest, 0, pwd, SALT_LENGTH, digest.length);  //将字节数组格式加密后的口令转化为16进制字符串格式的口令  return byteToHexString(pwd); }}测试类——Client,代码如下:package com.zyg.security.md5;import java.io.UnsupportedEncodingException;import java.security.NoSuchAlgorithmException;import java.util.HashMap;import java.util.Map;public class Client { private static Map users = new HashMap();  public static void main(String[] args){  String userName = "zyg";  String password = "123";  registerUser(userName,password);    userName = "changong";  password = "456";  registerUser(userName,password);    String loginUserId = "zyg";  String pwd = "1232";  try {   if(loginValid(loginUserId,pwd)){    System.out.println("欢迎登陆!!!");   }else{    System.out.println("口令错误,请重新输入!!!");   }  } catch (NoSuchAlgorithmException e) {   // TODO Auto-generated catch block   e.printStackTrace();  } catch (UnsupportedEncodingException e) {   // TODO Auto-generated catch block   e.printStackTrace();  }  }  /**  * 注册用户  *   * @param userName  * @param password  */ public static void registerUser(String userName,String password){  String encryptedPwd = null;  try {   encryptedPwd = MyMD5Util.getEncryptedPwd(password);      users.put(userName, encryptedPwd);     } catch (NoSuchAlgorithmException e) {   // TODO Auto-generated catch block   e.printStackTrace();  } catch (UnsupportedEncodingException e) {   // TODO Auto-generated catch block   e.printStackTrace();  } }  /**  * 验证登陆  *   * @param userName  * @param password  * @return  * @throws UnsupportedEncodingException   * @throws NoSuchAlgorithmException   */ public static boolean loginValid(String userName,String password)     throws NoSuchAlgorithmException, UnsupportedEncodingException{  String pwdInDb = (String)users.get(userName);  if(null!=pwdInDb){ // 该用户存在    return MyMD5Util.validPassword(password, pwdInDb);  }else{   System.out.println("不存在该用户!!!");   return false;  } }}

转载地址:http://egszm.baihongyu.com/

你可能感兴趣的文章
iStaing获500万美元投资,VR室内设计离我们还远吗?
查看>>
Java日志框架-Spring中使用Logback(Spring/Spring MVC)
查看>>
读书笔记--101个shell脚本 之#12--函数
查看>>
TCP/IP之(四)Delay ack 和 Nagle算法
查看>>
linux学习:selinux 禁用后(disabled)Linux系统无法正常启动解决
查看>>
关于tomcat和jetty对比(不喜欢jetty的勿看)
查看>>
grafana使用详解
查看>>
linux 文件同步 rsync+crontab
查看>>
git如何删除远程仓库的某次错误提交
查看>>
LAMP架构讲解(续一)
查看>>
linux下查看文件编码及修改编码
查看>>
VC中的延时
查看>>
算法与数据结构知识点
查看>>
在单位成功实验的PIX配置
查看>>
centos6.x使用dd命令制作u盘启动
查看>>
如何使用Wireshark抓包
查看>>
mysql 时间函数用法 集合
查看>>
技术宅男既要提升编程技术也要加强沟通能力
查看>>
开源计划--格瓦拉梦想(GUEVARA‘S DREAM)
查看>>
show full columns 和 checking privileges的说明
查看>>