java实现MD5加盐加密⽅法⼀、MD5如何使⽤Java代码⽣成
1. 第⼀、 得到原始数据的数据指纹
2. 第⼆、 因为的到数据指纹是乱码的,所以要通过base64编码成明⽂字符
⼆、应⽤场景:
密码加密
软件校对是否已修改过
获得指定长度的随机数
………
………
………
三、⼯具代码:
package com.lnsf.warehouse.util;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Random;
import dec.binary.Hex;
/**
* @author hh@163:
* @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 = Instance("MD5");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
System.out.String());
return "";
}
// 将加密字符串转换为字符数组
char[] charArray = CharArray();
char[] charArray = CharArray();
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.HexString(var));
}
String();
}
/**
* 普通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[] = Bytes("UTF-8");
MessageDigest mdTemp = Instance("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>
*              <p>
* @Author : HuaZai
*        </p>
*        <p>
* @Date : 2017年12⽉26⽇下午3:34:17
*      </p>
*/
public static String getconvertMD5(String inStr) {
char[] charArray = CharArray();
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 = Instance("MD5");
byte[] digest = md.Bytes());
return new String(new Hex().encode(digest));
} catch (Exception e) {
e.printStackTrace();
System.out.String());
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.Int(99999999)).Int(99999999));
sBuilder.Int(99999999)).Int(99999999));  int len = sBuilder.length();
if (len < 16) {
for (int i = 0; i < 16 - len; i++) {
sBuilder.append("0");
}
}
// ⽣成最终的加密盐
String Salt = String();
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);
}
/**
java生成随机数的方法* 验证加盐后是否和原⽂⼀致
* <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.vertMD5(strMD5)));
System.out.println("\t\t=======================================");
// 原⽂
String plaintext = "huazai";
// plaintext = "123456";
System.out.println("原始:" + plaintext);
System.out.println("普通MD5后:" + StrMD5(plaintext));
// 获取加盐后的MD5值
String ciphertext = SaltMD5(plaintext);
String ciphertext = SaltMD5(plaintext);
System.out.println("加盐后MD5:" + ciphertext);
System.out.println("是否是同⼀字符串:" + SaltverifyMD5(plaintext, ciphertext));  /**
* 其中某次DingSai字符串的MD5值
*/
String[] tempSalt = { "810e1ee9ee5e28188658f431451a29c2d81048de6a108e8a",
"66db82d9da2e35c95416471a147d12e46925d38e1185c043",
"61a718e4c15d914504a41d95230087a51816632183732b5a" };
for (String temp : tempSalt) {
System.out.println("是否是同⼀字符串:" + SaltverifyMD5(plaintext, temp));
}
}
}
测试结果:

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。