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];//根据长度转换成bytefor (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解密
md5在线解密破解,md5解密加密 (cmd5.com)
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);