当前位置: 首页 > news >正文

RSA非对称加密算法(Java实现)

废话不多说,直接上代码

public class RSAService {private static final String RSA = "RSA";private static final String PUBLIC_KEY = "xxx";private static final String PRIVATE_KEY = "xxx";public static void main(String[] args) throws Exception {// 生成密钥对KeyPair keyPair = generateKeyPair();PublicKey publicKey = keyPair.getPublic();PrivateKey privateKey = keyPair.getPrivate();// 公钥和私钥的Base64编码表示String publicKeyBase64 = Base64.getUrlEncoder().encodeToString(publicKey.getEncoded());String privateKeyBase64 = Base64.getUrlEncoder().encodeToString(privateKey.getEncoded());System.out.println("公钥: " + publicKeyBase64);System.out.println("私钥: " + privateKeyBase64);RSAService rsaService = new RSAService();// 原文HashMap<String, Object> map = new HashMap<>();map.put("data", "Hello, RSA!");// 公钥加密String encryptedText = rsaService.encrypt(JSON.toJSONString(map));System.out.println("加密后: " + encryptedText);// 私钥解密String decryptedText = rsaService.decrypt(encryptedText);}// 生成密钥对public static KeyPair generateKeyPair() throws Exception {KeyPairGenerator keyGen = KeyPairGenerator.getInstance(RSA);keyGen.initialize(2048);return keyGen.generateKeyPair();}// 使用公钥加密public String encrypt(String data) throws Exception {byte[] keyBytes = Base64.getUrlDecoder().decode(PUBLIC_KEY);X509EncodedKeySpec spec = new X509EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance(RSA);PublicKey publicKey = keyFactory.generatePublic(spec);Cipher cipher = Cipher.getInstance(RSA);cipher.init(Cipher.ENCRYPT_MODE, publicKey);byte[] bytes = cipher.doFinal(data.getBytes());//二进制码转字符串String base64Encoded = Base64.getUrlEncoder().encodeToString(bytes);return base64Encoded;}// 使用私钥解密public String decrypt(String data) throws Exception {byte[] keyBytes = Base64.getUrlDecoder().decode(PRIVATE_KEY);byte[] dataBytes = Base64.getUrlDecoder().decode(data);PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance(RSA);PrivateKey privateKey = keyFactory.generatePrivate(spec);Cipher cipher = Cipher.getInstance(RSA);cipher.init(Cipher.DECRYPT_MODE, privateKey);byte[] bytes = cipher.doFinal(dataBytes);return new String(bytes);}
}
http://www.lryc.cn/news/408208.html

相关文章:

  • netty构建http服务器
  • Docker中安装Kafka和Kafka UI管理界面
  • 防火墙——SNAT和DNAT策略的原理及应用、防火墙规则的备份、还原和抓包
  • C# 冒泡排序
  • 网络传输层——UDP与TCP
  • Hype 4 Pro for Mac:专业级HTML5动画制作利器
  • C++ STL remove, remove_if 用法
  • HarmonyOS NEXT 开发之ArkTS基础入门
  • UE5 C++跑酷练习(Part2)
  • 从0开始搭建vue + flask 旅游景点数据分析系统(二):搭建基础框架
  • 【过滤器 vs 拦截器】SpringBoot中过滤器与拦截器:明智选择的艺术(如何在项目中做出明智选择)
  • 2024-06学习笔记
  • 【VUE】封装一个追随鼠标的漂浮组件框架
  • mapstruct与lombok结合使用
  • 【SpringBoot】Web开发之URL映射
  • 对递归的一些理解。力扣206题:翻转链表
  • Kafka面试三道题
  • C/C++编程-算法学习-数字滤波器
  • maven介绍 搭建Nexus3(maven私服搭建)
  • 电商项目之如何判断线程池是否执行完所有任务
  • 【前端 15】Vue生命周期
  • PCIe总线-Linux内核PCIe软件框架分析(十一)
  • 视觉SLAM第二讲
  • mysql1055报错解决方法
  • Java的@DateTimeFormat注解与@JsonFormat注解的使用对比
  • 德国云手机:企业移动办公解决方案
  • 【React】useState:状态管理的基石
  • 商品中心关于缓存热key的解决方案
  • 【Python系列】Parquet 数据处理与合并:高效数据操作实践
  • 大脑自组织神经网络通俗讲解