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));
}
}
}
測試結果:
相關文章
- java MD5 加密實現Java加密
- python_hashlib,md5,getpass, 密碼加密,隱藏,加鹽Python密碼加密
- Golang兩種方法實現MD5加密Golang加密
- C# 實現MD5加密處理 MD5 加密C#加密
- qt實現md5加密QT加密
- Javascript實現MD5加密JavaScript加密
- 短連結演算法實現–加鹽hash演算法
- python 實現md5加密Python加密
- java MD5 加密Java加密
- 【Java】MD5加密Java加密
- java md5加密Java加密
- SSO(單點登入)MD5加鹽 原理案例教程 火推
- 如何鹽加密加密
- 使用雜湊加鹽法來為密碼加密【轉】密碼加密
- 鹽值加密概念加密
- JAVA中MD5加密(MD5工具類)Java加密
- 淺談md5加密 以及C++實現加密C++
- JavaScript實現的base64加密、md5加密、sha1加密及AES加密JavaScript加密
- 爆破MD5加密程式――驅動之加 1.21 [VB]加密
- java md5加密的幾種方式Java加密
- C語言實現MD5加密,竟如此簡單!C語言加密
- MD5加密加密
- 加密鹽的意義和用途加密
- md5加密解密加密解密
- iOS MD5加密iOS加密
- Java實現密碼、檔案MD5加密,密碼sha256、sha384、sha512Hex等加密Java密碼加密
- Vue 前端md5加密Vue前端加密
- 關於MD5加密加密
- oracle的md5加密Oracle加密
- MD5加密工具類加密
- 加鹽密碼雜湊:如何正確使用密碼
- VB實現AES(Rijndael)加密的方法加密
- Java常用加密演算法(一)—單向加密演算法(MD5/SHA)Java加密演算法
- Android資料加密之MD5加密Android加密
- 不用加減乘除做加法(Java實現)Java
- 加鹽hash儲存密碼的正確方式密碼
- Oracle和MySQL md5加密OracleMySql加密
- Oracle中的MD5加密Oracle加密