java实现MD5加盐加密方法

               

一、MD5如何使用Java代码生成

  • 第一、 得到原始数据的数据指纹
  • 第二、 因为的到数据指纹是乱码的,所以要通过base64编码成明文字符

二、应用场景:

密码加密 
软件校对是否已修改过 
获得指定长度的随机数 
……… 
……… 
………

三、工具代码:

package com.lnsf.warehouse.util;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;import java.util.Random;import org.apache.commons.codec.binary.Hex;/** * @author hh@163.com:  * @version 创建时间:2018-3-20 下午2:40:13  * @introduction */public class MD5Utils /**  * 普通MD5加密 01  * <p>  *   * @Title : getStrMD5  *        </p>  *        <p>  * @Description : TODO  *              </p>  *              <p>  * @Author : HuaZai  *         </p>  *         <p>  * @Date : 2017年12月26日 下午2:49:44  *       </p>  */ public static String getStrMD5(String inStr) {  // 获取MD5实例  MessageDigest md5 = null;  try {   md5 = MessageDigest.getInstance("MD5");  } catch (NoSuchAlgorithmException e) {   e.printStackTrace();   System.out.println(e.toString());   return "";  }  // 将加密字符串转换为字符数组  char[] charArray = inStr.toCharArray();  byte[] byteArray = new byte[charArray.length];  // 开始加密  for (int i = 0; i < charArray.length; i++)   byteArray[i] = (byte) charArray[i];  byte[] digest = md5.digest(byteArray);  StringBuilder sb = new StringBuilder();  for (int i = 0; i < digest.length; i++) {   int var = digest[i] & 0xff;   if (var < 16)    sb.append("0");   sb.append(Integer.toHexString(var));  }  return sb.toString(); } /**  * 普通MD5加密 02  * <p>  *   * @Title : getStrrMD5  *        </p>  *        <p>  * @Description : TODO  *              </p>  *              <p>  * @Author : HuaZai  *         </p>  *         <p>  * @Date : 2017年12月27日 上午11:18:39  *       </p>  */ public static String getStrrMD5(String password) {  char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };  try {   byte strTemp[] = password.getBytes("UTF-8");   MessageDigest mdTemp = MessageDigest.getInstance("MD5");   mdTemp.update(strTemp);   byte md[] = mdTemp.digest();   int j = md.length;   char str[] = new char[j * 2];   int k = 0;   for (int i = 0; i < j; i++) {    byte byte0 = md[i];    str[k++] = hexDigits[byte0 >>> 4 & 15];    str[k++] = hexDigits[byte0 & 15];   }   return new String(str);  } catch (Exception e) {   return null;  } } /**  * MD5双重解密  * <p>  *   * @Title : getconvertMD5  *        </p>  *        <p>  * @Description : TODO  *              </p>  *              <p>  * @Author : HuaZai  *         </p>  *         <p>  * @Date : 2017年12月26日 下午3:34:17  *       </p>  */ public static String getconvertMD5(String inStr) {  char[] charArray = inStr.toCharArray();  for (int i = 0; i < charArray.length; i++) {   charArray[i] = (char) (charArray[i] ^ 't');  }  String str = String.valueOf(charArray);  return str; } /**  * 使用Apache的Hex类实现Hex(16进制字符串和)和字节数组的互转  * <p>  *   * @Title : md5Hex  *        </p>  *        <p>  * @Description : TODO  *              </p>  *              <p>  * @Author : HuaZai  *         </p>  *         <p>  * @Date : 2017年12月27日 上午11:28:25  *       </p>  */ @SuppressWarnings("unused"private static String md5Hex(String str) {  try {   MessageDigest md = MessageDigest.getInstance("MD5");   byte[] digest = md.digest(str.getBytes());   return new String(new Hex().encode(digest));  } catch (Exception e) {   e.printStackTrace();   System.out.println(e.toString());   return "";  } } /**  * 加盐MD5加密  * <p>  *   * @Title : getSaltMD5  *        </p>  *        <p>  * @Description : TODO  *              </p>  *              <p>  * @Author : HuaZai  *         </p>  *         <p>  * @Date : 2017年12月27日 上午11:21:00  *       </p>  */ public static String getSaltMD5(String password) {  // 生成一个16位的随机数  Random random = new Random();  StringBuilder sBuilder = new StringBuilder(16);  sBuilder.append(random.nextInt(99999999)).append(random.nextInt(99999999));  int len = sBuilder.length();  if (len < 16) {   for (int i = 0; i < 16 - len; i++) {    sBuilder.append("0");   }  }  // 生成最终的加密盐  String Salt = sBuilder.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 String.valueOf(cs); } /**  * 验证加盐后是否和原文一致  * <p>  *   * @Title : verifyMD5  *        </p>  *        <p>  * @Description : TODO  *              </p>  *              <p>  * @Author : HuaZai  *         </p>  *         <p>  * @Date : 2017年12月27日 下午2:22:22  *       </p>  */ public static boolean getSaltverifyMD5(String password, String md5str) {  char[] cs1 = new char[32];  char[] cs2 = new char[16];  for (int i = 0; i < 48; i += 3) {   cs1[i / 3 * 2] = md5str.charAt(i);   cs1[i / 3 * 2 + 1] = md5str.charAt(i + 2);   cs2[i / 3] = md5str.charAt(i + 1);  }  String Salt = new String(cs2);  return md5Hex(password + Salt).equals(String.valueOf(cs1)); } public static void main(String[] args) {  MD5Utils md = new MD5Utils();  String strMD5 = new String("12345");  System.out.println("原始:" + strMD5);  System.out.println("东东的:" + md.getStrrMD5(strMD5));  System.out.println("MD5后:" + md.getStrMD5(strMD5));  System.out.println("加密的:" + md.getconvertMD5(strMD5));  System.out.println("解密的:" + md.getconvertMD5(md.getconvertMD5(strMD5)));  System.out.println("\t\t=======================================");  // 原文  String plaintext = "huazai";  // plaintext = "123456";  System.out.println("原始:" + plaintext);  System.out.println("普通MD5后:" + MD5Utils.getStrMD5(plaintext));  // 获取加盐后的MD5值  String ciphertext = MD5Utils.getSaltMD5(plaintext);  System.out.println("加盐后MD5:" + ciphertext);  System.out.println("是否是同一字符串:" + MD5Utils.getSaltverifyMD5(plaintext, ciphertext));  /**   * 其中某次DingSai字符串的MD5值   */  String[] tempSalt = { "810e1ee9ee5e28188658f431451a29c2d81048de6a108e8a",    "66db82d9da2e35c95416471a147d12e46925d38e1185c043",    "61a718e4c15d914504a41d95230087a51816632183732b5a" };  for (String temp : tempSalt) {   System.out.println("是否是同一字符串:" + MD5Utils.getSaltverifyMD5(plaintext, temp));  } }}

测试结果:


           
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值