加密算法主要分为三类,单向加密,对称加密,非对称加密。
单向加密即加密之后不能解密,一般用于数据验证。
Base64 编码是从二进制到字符的过程,用 64 个字符来表示任意的二进制数据,常用于在 HTTP 加密,图片编码传输等。
MD5加密的全称是(Message Digest algorithm 5,信息摘要算法)。
SHA加密全称是(Secure Hash Algorithm,安全散列算法)。
HMAC加密全称是(Hash Message Authentication Code,散列消息鉴别码)。
MD5、SHA、HMAC这三种加密算法,是非可逆加密,不可解密的加密方法。只能进行简单的加密。
对称加密的意思就是信息收发都有相同的一把钥匙,消息的加密解密都用这进行
DES加密全称是(Data Encryption Standard,数据加密算法)。
PBE加密的全称是(Password-based encryption,基于密码验证)
AES的全称是(Advanced Encryption Standard)
高级加密标准,是下一代的加密算法标准,速度快,安全级别高;
非对称加密算法是一种密钥的保密方法。 非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(privatekey)。 公开密钥与私有密钥是一对,如果用公开密钥对数据进行加密,只有用对应的私有密钥才能解密;如果用私有密钥对数据进行加密,那么只有用对应的公开密钥才能解密。
RSA(算法的名字以发明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman)
DH(Diffie-Hellman算法,密钥一致协议)
DAS(Digital Signature Algorithm,数字签名算法,是一种标准的 DSS(数字签名标准);)
ECC(Elliptic Curves Cryptography,椭圆曲线密码编码学).
/**
* 使用sun.misc.BASE64Encoder类或者java.util.Base64.getEncoder()加密
* 使用sun.misc.BASE64Decoder类或者java.util.Base64.getDecoder()解密
*/
public static void testBase64() {
try {
// 加密
String encode = (new BASE64Encoder()).encodeBuffer("this a test".getBytes());
System.out.println(encode);
// 解密
byte[] decode = new BASE64Decoder().decodeBuffer(encode);
System.out.println(new String(decode, "UTF-8"));
} catch (Exception e) {
e.printStackTrace();
}
}
public class Coder {
/**
* SHA算法可选以下多种算法
*
*
* SHA
* SHA-1
* SHA-256
*
*/
public static final String KEY_SHA = "SHA";
public static final String KEY_MD5 = "MD5";
/**
* MD5加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptMD5(byte[] data) throws Exception {
MessageDigest md5 = MessageDigest.getInstance(KEY_MD5);
md5.update(data);
return md5.digest();
}
/**
* SHA加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptSHA(byte[] data) throws Exception {
// messageDigest = MessageDigest.getInstance("SHA-1");
// messageDigest = MessageDigest.getInstance("SHA-256");
MessageDigest sha = MessageDigest.getInstance(KEY_SHA);
sha.update(data);
return sha.digest();
}
public static void main(String[] args) throws Exception {
byte[] first = Coder.encryptMD5("this is test".getBytes());
byte[] sencode = Coder.encryptMD5("this is test".getBytes());
}
}
public class Coder {
/**
* HMAC算法可选以下多种算法
*
*
* HmacMD5
* HmacSHA1
* HmacSHA256
* HmacSHA384
* HmacSHA512
*
*/
public static final String KEY_MAC = "HmacMD5";
private static byte[] initMacKey() throws Exception {
KeyGenerator keyGenerator = KeyGenerator.getInstance(KEY_MAC);
SecretKey secretKey = keyGenerator.generateKey();
return secretKey.getEncoded();
}
/**
* HMAC加密
*
* @param data
* @return
* @throws Exception
*/
public static byte[] encryptHMAC(byte[] data, byte[] key) throws Exception {
SecretKey secretKey = new SecretKeySpec(key, KEY_MAC);
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
return mac.doFinal(data);
}
public static void main(String[] args) throws Exception {
byte[] key = initMacKey();
byte[] first = encryptHMAC("this is test".getBytes(), key);
byte[] seconde = encryptHMAC("this is test".getBytes(), key);
BigInteger mac = new BigInteger(first);
System.err.println("HMAC:\n" + mac.toString(16));
BigInteger mac2 = new BigInteger(seconde);
System.err.println("HMAC:\n" + mac2.toString(16));
}
}
参考:
https://www.cnblogs.com/wangjintao-0623/p/10460268.html