Java的加密算法
Java的加密算法
密码学算法分类
消息编码:Base64
消息摘要:MD类,SHA类,MAC
对称加密:DES,3DES,AES
非对称加密:RSA,DH密钥交换
数字签名:RSA signature,DSA signature
1. JDK提供的Base64编码操作
Base64Util工具类
package com.hzxy.test.utils;
import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;
import java.io.IOException;
/*
* base64编码工具
* ye
* 2021.5.11
* */
public class Base64Util {
public static String encrypt(byte[] data) {
return new BASE64Encoder().encode(data);
}
public static String decrypt(String data) throws IOException {
return new String(new BASE64Decoder().decodeBuffer(data));
}
}
测试方法:
@Test
void testBase64Util() throws IOException {
String data = "123456";
String result = Base64Util.encrypt(data.getBytes());
System.out.println(data +" 使用Base64编码的结果: " + result);
String result2 = Base64Util.decrypt(result);
System.out.println(result + "使用Base64解码的结果:" + result2);
}
结果:
2. 消息摘要算法(MD5、SHA、HMAC)
消息摘要是对消息通过一个单向Hash算法进行计算,得到一个唯一的结果。每个消息对应一个唯一结果,所有结果的长度固定。应用于校验数据的完整性,防止在传输途中被篡改。
消息摘要主要有以下三个:
- MD5(Message Digest)消息摘要算法
- SHA(Secure Hash Algorithm)安全散列算法
- MAC(Message Authentication Code)消息认证码算法,结合了MD5和SHA的优势,同时用密钥对摘要进行加密,是一种更为安全的消息摘要算法。
具体的使用:
BytesToHex 工具类
package com.hzxy.test.utils;
/*
* BytesToHex工具
* ye
* 2021.5.11
* */
public class BytesToHex {
public static String fromBytesToHex(byte[] resultBytes) {
StringBuilder builder = new StringBuilder();
for (int i = 0; i < resultBytes.length; i++) {
if (Integer.toHexString(0xFF & resultBytes[i]).length() == 1) {
builder.append("0").append(
Integer.toHexString(0xFF & resultBytes[i]));
} else {
builder.append(Integer.toHexString(0xFF & resultBytes[i]));
}
}
return builder.toString();
}
}
MessageDigestUtil 工具类
package com.hzxy.test.utils;
import java.io.File;
import java.io.FileInputStream;
import java.security.DigestInputStream;
import java.security.MessageDigest;
import javax.crypto.KeyGenerator;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
/*
* MessageDigestUtil工具
* ye
* 2021.5.11
* */
public class MessageDigestUtil {
/**
* 计算MD5值
*/
public static String encryptMD5(byte[] data) throws Exception {
MessageDigest messageDigest = MessageDigest.getInstance("MD5");//MD5,MD2
messageDigest.update(data);
return BytesToHex.fromBytesToHex(messageDigest.digest());
}
/**
* 计算文件的MD5值(指纹签名)
*/
public static String getFileMD5(String path) throws Exception {
FileInputStream fis = new FileInputStream(new File(path));
DigestInputStream dis = new DigestInputStream(fis, MessageDigest.getInstance("MD5"));
try {
byte[] buffer = new byte[1024];
int read = dis.read(buffer, 0, 1024);
while (read != -1) {
read = dis.read(buffer, 0, 1024);
}
MessageDigest md = dis.getMessageDigest();
return BytesToHex.fromBytesToHex(md.digest());
} finally {
dis.close();
fis.close();
}
}
/**
* 计算SHA值
*/
public static String encryptSHA(byte[] data) throws Exception {
MessageDigest messageDigest = MessageDigest.getInstance("SHA"