java 加密解密
1.使用MD5后台加密
//密码MD5加密
public String testMD5(String pwd) {
//加盐
String salt = "sssss";
// 基于spring框架中的DigestUtils工具类进行密码加密
String hashedPwd1 = DigestUtils.md5DigestAsHex((salt+pwd ).getBytes());
System.out.println(hashedPwd1);
return hashedPwd1;
}
2.js前台加密
前台使用post 传值,为了以防泄露,加密一下传参
function encryption(str) {
var encStr = encodeURIComponent(str);
encStr = btoa(encStr);
return encStr;
}
3.后台解密
private static String base64hash = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
/**
* 解密字符串
* @return
*/
public static String decrypt(String str) {
String atob = atob(str);
try {
String decode = URLDecoder.decode(atob, "utf-8");
return decode;
} catch (UnsupportedEncodingException e) {
System.out.println("atob加密函数出现错误。");
}
return str;
}
/**
* atob method 逆转encode的思路即可
* @param inStr
* @return
*/
public static String atob(String inStr) {
if (inStr == null)
return null;
inStr = inStr.replaceAll("\\s|=", "");
StringBuilder result = new StringBuilder();
int cur;
int prev = -1;
int mod;
int i = 0;
while (i < inStr.length()) {
cur = base64hash.indexOf(inStr.charAt(i));
mod = i % 4;
switch (mod) {
case 0:
break;
case 1:
result.append(String.valueOf((char) (prev << 2 | cur >> 4)));
break;
case 2:
result.append(String.valueOf((char) ((prev & 0x0f) << 4 | cur >> 2)));
break;
case 3:
result.append(String.valueOf((char) ((prev & 3) << 6 | cur)));
break;
}
prev = cur;
i++;
}
return result.toString();
}
本文有引用学习其他文章
链接: https://blog.csdn.net/flowerStream/article/details/117506260