1、MD5的加密方式是一種哈希加密。一些主流的程式設計語言都已經實作了MD5的加密。
2、MD5在明文的情況下,MD5就可以加密。
3、MD5是不可逆的,隻能加密,不能解密。
思路:
1、接收方和發送方先确定一個key(用于保證資料和驗證碼正确)
2、對資料+key進行MD5加密,生成MD5校驗碼
3、把資料和檢驗碼一起傳到接收方
4、接收方接用收到的資料+自己手上的key進行MD5加密
5、對比兩個MD5,确認資料是否正确
代碼:
import java.security.MessageDigest;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
public class MD5Test {
public static void main(String[] args) {
//用戶端所需要傳輸的資料加上key 一起傳給MD5Encode 生成MD5
//用戶端傳輸資料的時候不傳key
//服務端用服務端手上的key和接收到的資料再生成一個MD5來對比 以此保證資料正确
String str= "1";
String clientkey = "sw23klkj3nm23";
String clientstr = str + clientkey;
//生成MD5
String result = MD5Test.MD5Encode(clientstr, "UTF-8").toUpperCase();
System.out.println(result);
//用接收到的資料生成一個新的MD5 與原來的MD5對比
String checkstr = "1";
String serverkey = "sw23klkj3nm23";
String serverstr = checkstr + serverkey;
System.out.print("驗證密碼是否正确:");
if(validatePassword(result, serverstr, "UTF-8")) {
System.out.println("正确");
}
else {
System.out.println("錯誤");
}
}
//通過擷取參數并且生成新的MD5校驗碼 然後和 擷取到的MD5校驗碼 對比 以此驗證傳過來的資料是否被修改
public static boolean validatePassword(String origin, String inputString, String charsetname){
if(origin.equals(MD5Encode(inputString,charsetname).toUpperCase())){
return true;
} else{
return false;
}
}
//通過擷取資料來生成MD5驗證碼 charsetname為"UTF-8"編碼比較好
public static String MD5Encode(String origin, String charsetname) {
String resultString = null;
try {
resultString = new String(origin);
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] digestString = md.digest(resultString.getBytes(charsetname));
if (charsetname == null || "".equals(charsetname))
resultString = byteArrayToHexString(digestString);
else
resultString = byteArrayToHexString(digestString);
} catch (Exception exception) {
}
return resultString;
}
//生成MD5序列的邏輯
private static String byteArrayToHexString(byte b[]) {
StringBuffer resultSb = new StringBuffer();
String byteToHex = null;
for (int i = ; i < b.length; i++){
byteToHex = byteToHexString(b[i]);
resultSb.append(byteToHex);
}
return resultSb.toString();
}
//邏輯中每一位資料 在這裡對應轉換成兩個字元
private static String byteToHexString(byte b) {
int n = b;
if (n < )
n += ;
int d1 = n / ;
int d2 = n % ;
return hexDigits[d1] + hexDigits[d2];
}
//轉換字元的集合 這裡可以根據自己喜好改一下順序 達到改變生成的MD5的結果的作用 慢慢試 估計可能可以清楚順序的
private static final String hexDigits[] = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
}
MD5加密這個東西估計就這樣先了,做個模闆,下次可以直接複制粘貼。