AES 加解密 & RSA加解密
作者:互联网
Java实现aes加解密
https://blog.csdn.net/lh155136/article/details/119348435
Java加密-AES加解密
https://www.jianshu.com/p/7f17792609cc
RSA加解密工具类RSAUtils.java,实现公钥加密私钥解密和私钥解密公钥解密
https://blog.csdn.net/m0_59133441/article/details/122686815
Java实现aes加解密
pom文件的依赖
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-lang3 --> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.4</version> </dependency> <!-- https://mvnrepository.com/artifact/commons-codec/commons-codec --> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.8</version> </dependency>
package com.xxl.job.admin.util; import org.apache.commons.codec.binary.Base64; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import sun.misc.BASE64Decoder; import javax.crypto.Cipher; import javax.crypto.KeyGenerator; import javax.crypto.spec.SecretKeySpec; import java.nio.charset.StandardCharsets; /** * aes加解密工具类 * * @author liHu * @version 1.0 * @date 2021/8/3 10:48 * @since JDK 1.8 */ public class EncryptAesUtil { private static Logger logger = LoggerFactory.getLogger(EncryptAesUtil.class); /** * 密钥 AES加解密要求key必须要128个比特位(这里需要长度为16,否则会报错) */ private static final String KEY = "xxl_job_12345678"; /** * 算法 */ private static final String ALGORITHMS = "AES/ECB/PKCS5Padding"; /** * 静态常量 */ private static final String AES = "AES"; public static void main(String[] args) { logger.info("加密密钥和解密密钥:{}", KEY); String content = "SBAZCSJYBAGDYQDF"; logger.info("加密前:" + content); String encrypt = aesEncrypt(content); logger.info("加密后:" + encrypt); String decrypt = aesDecrypt(encrypt); logger.info("解密后:" + decrypt); } /** * 将字符串【AES加密】为base 64 code * * @param content 待加密的内容 * @return 加密后的base 64 code */ public static String aesEncrypt(String content) { try { // 创建密码器 KeyGenerator kgen = KeyGenerator.getInstance("AES"); kgen.init(128); // 初始化为加密模式的密码器 Cipher cipher = Cipher.getInstance(ALGORITHMS); cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(EncryptAesUtil.KEY.getBytes(), EncryptAesUtil.AES)); byte[] bytes = cipher.doFinal(content.getBytes(StandardCharsets.UTF_8)); // 使用base64解码 return Base64.encodeBase64String(bytes); } catch (Exception e) { logger.error(e.getMessage() + e); } return null; } /** * 将base 64 code 【AES解密】为字符串 * * @param encryptStr 待解密的base 64 code * @return 解密后的String */ public static String aesDecrypt(String encryptStr) { try { if (StringUtils.isEmpty(encryptStr)) { return null; } // 将字符串转为byte,返回解码后的byte[] byte[] encryptBytes = new BASE64Decoder().decodeBuffer(encryptStr); // 创建密码器 KeyGenerator kgen = KeyGenerator.getInstance(EncryptAesUtil.AES); kgen.init(128); // 初始化为解密模式的密码器 Cipher cipher = Cipher.getInstance(ALGORITHMS); cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(EncryptAesUtil.KEY.getBytes(), EncryptAesUtil.AES)); byte[] decryptBytes = cipher.doFinal(encryptBytes); return new String(decryptBytes); } catch (Exception e) { logger.error(e.getMessage() + e); } return null; } }
____________________________________________________________________________________________________________________________________________________________________________________________________
RSA加解密工具类RSAUtils.java
package com.geostar.gfstack.cas.util; import org.apache.commons.codec.binary.Base64; import javax.crypto.Cipher; import java.security.*; import java.security.interfaces.RSAPrivateKey; import java.security.interfaces.RSAPublicKey; import java.security.spec.PKCS8EncodedKeySpec; import java.security.spec.X509EncodedKeySpec; /** * RSA加解密工具类,实现公钥加密私钥解密和私钥解密公钥解密 */ public class RSAUtils { private static final String src = "abcdefghijklmnopqrstuvwxyz"; public static void main(String[] args) throws Exception { System.out.println("\n"); RSAKeyPair keyPair = generateKeyPair(); System.out.println("公钥:" + keyPair.getPublicKey()); System.out.println("私钥:" + keyPair.getPrivateKey()); System.out.println("\n"); test1(keyPair, src); System.out.println("\n"); test2(keyPair, src); System.out.println("\n"); } /** * 公钥加密私钥解密 */ private static void test1(RSAKeyPair keyPair, String source) throws Exception { System.out.println("***************** 公钥加密私钥解密开始 *****************"); String text1 = encryptByPublicKey(keyPair.getPublicKey(), source); String text2 = decryptByPrivateKey(keyPair.getPrivateKey(), text1); System.out.println("加密前:" + source); System.out.println("加密后:" + text1); System.out.println("解密后:" + text2); if (source.equals(text2)) { System.out.println("解密字符串和原始字符串一致,解密成功"); } else { System.out.println("解密字符串和原始字符串不一致,解密失败"); } System.out.println("***************** 公钥加密私钥解密结束 *****************"); } /** * 私钥加密公钥解密 * * @throws Exception */ private static void test2(RSAKeyPair keyPair, String source) throws Exception { System.out.println("***************** 私钥加密公钥解密开始 *****************"); String text1 = encryptByPrivateKey(keyPair.getPrivateKey(), source); String text2 = decryptByPublicKey(keyPair.getPublicKey(), text1); System.out.println("加密前:" + source); System.out.println("加密后:" + text1); System.out.println("解密后:" + text2); if (source.equals(text2)) { System.out.println("解密字符串和原始字符串一致,解密成功"); } else { System.out.println("解密字符串和原始字符串不一致,解密失败"); } System.out.println("***************** 私钥加密公钥解密结束 *****************"); } /** * 公钥解密 * * @param publicKeyText * @param text * @return * @throws Exception */ public static String decryptByPublicKey(String publicKeyText, String text) throws Exception { X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyText)); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec); Cipher cipher = Cipher.getInstance("RSA"); cipher.init(Cipher.DECRYPT_MODE, publicKey); byte[] result = cipher.doFinal(Base64.decodeBase64(text)); return new String(result); } /** * 私钥加密 * * @param privateKeyText * @param text * @return * @throws Exception */ public static String encryptByPrivateKey(String privateKeyText, String text) throws Exception { PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyText)); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec); Cipher cipher = Cipher.getInstance("RSA"); cipher.init(Cipher.ENCRYPT_MODE, privateKey); byte[] result = cipher.doFinal(text.getBytes()); return Base64.encodeBase64String(result); } /** * 私钥解密 * * @param privateKeyText * @param text * @return * @throws Exception */ public static String decryptByPrivateKey(String privateKeyText, String text) throws Exception { PKCS8EncodedKeySpec pkcs8EncodedKeySpec5 = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyText)); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec5); Cipher cipher = Cipher.getInstance("RSA"); cipher.init(Cipher.DECRYPT_MODE, privateKey); byte[] result = cipher.doFinal(Base64.decodeBase64(text)); return new String(result); } /** * 公钥加密 * * @param publicKeyText * @param text * @return */ public static String encryptByPublicKey(String publicKeyText, String text) throws Exception { X509EncodedKeySpec x509EncodedKeySpec2 = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyText)); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec2); Cipher cipher = Cipher.getInstance("RSA"); cipher.init(Cipher.ENCRYPT_MODE, publicKey); byte[] result = cipher.doFinal(text.getBytes()); return Base64.encodeBase64String(result); } /** * 构建RSA密钥对 * * @return * @throws NoSuchAlgorithmException */ public static RSAKeyPair generateKeyPair() throws NoSuchAlgorithmException { KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA"); keyPairGenerator.initialize(1024); KeyPair keyPair = keyPairGenerator.generateKeyPair(); RSAPublicKey rsaPublicKey = (RSAPublicKey) keyPair.getPublic(); RSAPrivateKey rsaPrivateKey = (RSAPrivateKey) keyPair.getPrivate(); String publicKeyString = Base64.encodeBase64String(rsaPublicKey.getEncoded()); String privateKeyString = Base64.encodeBase64String(rsaPrivateKey.getEncoded()); RSAKeyPair rsaKeyPair = new RSAKeyPair(publicKeyString, privateKeyString); return rsaKeyPair; } /** * RSA密钥对对象 */ public static class RSAKeyPair { private String publicKey; private String privateKey; public RSAKeyPair(String publicKey, String privateKey) { this.publicKey = publicKey; this.privateKey = privateKey; } public String getPublicKey() { return publicKey; } public String getPrivateKey() { return privateKey; } } }
标签:System,AES,String,加解密,RSA,解密,Cipher,println,out 来源: https://www.cnblogs.com/kelelipeng/p/16314246.html