md5加密
/**
* 采用MD5加密解密
*
* MD5加码 生成32位md5码
*/
public static String string2MD5(String inStr) {
MessageDigest md5 = null;
try {
md5 = MessageDigest.getInstance("MD5");
} catch (Exception e) {
System.out.println(e.toString());
e.printStackTrace();
return "";
}
char[] charArray = inStr.toCharArray();//转成char数组类型
System.out.println("charArray.length = " + charArray.length);
byte[] byteArray = new byte[charArray.length];//根据长度转换成byte
for (int i = 0; i < charArray.length; i++){
byteArray[i] = (byte) charArray[i];
}
byte[] md5Bytes = md5.digest(byteArray);
System.out.println("md5Bytes.length = " + md5Bytes.length);
StringBuffer hexValue = new StringBuffer();//获取32位
for (int i = 0; i < md5Bytes.length; i++) {
int val = ((int) md5Bytes[i]) & 0xff;
if (val < 16) {
hexValue.append("0");
}
hexValue.append(Integer.toHexString(val));
System.out.println("Integer.toHexString(val) = " + Integer.toHexString(val));
}
return hexValue.toString().toUpperCase(); //.toUpperCase() 去掉字母就会变成小写。加上是大写
}
md5解密
sm4加密
SM4是一种分组密码算法,其分组长度为128位(即16字节,4字),密钥长度也为128位(即16字节,4字)。其加解密过程采用了32轮迭代机制(与DES、AES类似),每一轮需要一个轮密钥(与DES、AES类似)。
加密过程分为两步,由32次轮迭代和1次反序变换组成。
SM4的解密过程与加密过程完全相同,也包括32轮迭代和一次反序变换。只是在轮迭代的时候,需要将轮密钥逆序使用
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.7.20</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15to18</artifactId>
<version>1.69</version>
</dependency>
@Test
void contextLoads() {
String content="123456";
SM4 sm4 = SmUtil.sm4();
String encryptHex = sm4.encryptHex(content);
String decryptStr = sm4.decryptStr(encryptHex, CharsetUtil.CHARSET_UTF_8);
System.out.println(encryptHex+"======="+decryptStr);
}
sm4解密
@Test
void contextLoads() {
String content="123456";
SM4 sm4 = SmUtil.sm4();
String encryptHex = sm4.encryptHex(content); //加密
String decryptStr = sm4.decryptStr(encryptHex, CharsetUtil.CHARSET_UTF_8);//解密
System.out.println(encryptHex+"======="+decryptStr);
}
sha1加密
直接调用这个方法即可
String s = DigestUtils.sha1Hex(str);