java中RSA加密解密的使用

news/2024/12/16 14:07:28/文章来源:https://www.cnblogs.com/hongdanni/p/18609744

作为常用的非对称加密算法,本篇文章大致记录一下,在java代码中如何生成RSA的密钥对以及加密解密的使用。

1、生成密钥对

public class RSAUtils {// 填充方式public static final String RSA_ALGORITHM_NOPADDING = "RSA";public static final String RSA_ALGORITHM = "RSA/ECB/PKCS1Padding";/*** 生成密钥对* @return*/public static Map<String, String> createKeyPairs() {try {KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance(RSA_ALGORITHM_NOPADDING);keyPairGenerator.initialize(2048);KeyPair keyPair = keyPairGenerator.generateKeyPair();RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();return new HashMap<String, String>(){{put("publicKey", Base64.encodeBase64String(publicKey.getEncoded()));put("privateKey", Base64.encodeBase64String(privateKey.getEncoded()));}};} catch (NoSuchAlgorithmException e) {e.printStackTrace();}return null;}}

 

2、加密

    /*** 通过公钥对数据进行加密* @param publicKeyStr* @param data* @return*/public static String encryptRSADefault(String publicKeyStr, String data) {try {KeyFactory keyFactory = KeyFactory.getInstance(RSA_ALGORITHM_NOPADDING);  // 指定算法,返回keyFactory对象byte[] publicKeyByte = Base64.decodeBase64(publicKeyStr);  // 或:Base64.decodeBase64(publicKeyStr.getBytes())X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(publicKeyByte);  // 创建X509编码公钥规范PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec);  // 根据X5090编码密钥规范产生公钥对象Cipher cipher = Cipher.getInstance(RSA_ALGORITHM_NOPADDING);  // 根据算法名称,生成密码对象cipher.init(Cipher.ENCRYPT_MODE, publicKey);  // 使用公钥初始化cipher对象(encrypt加密模式)byte[] encryptByte = cipher.doFinal(data.getBytes());  // 对数据进行加密return Base64.encodeBase64String(encryptByte);  // 将字节数组,经过base64编码后,以US-ASCII编码输出为字符串} catch (Exception e) {e.printStackTrace();}return null;}

 

3、解密

    public static String decryptRSADefault(String privateKeyStr, String data) {try {KeyFactory keyFactory = KeyFactory.getInstance(RSA_ALGORITHM_NOPADDING);byte[] privateKeyByte = Base64.decodeBase64(privateKeyStr);PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(privateKeyByte);  //  密钥为pkcs8格式PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);  // 生成私钥对象Cipher cipher = Cipher.getInstance(RSA_ALGORITHM_NOPADDING);cipher.init(Cipher.DECRYPT_MODE, privateKey);byte[] decryptByte = cipher.doFinal(Base64.decodeBase64(data.getBytes()));return new String(decryptByte, "UTF-8");} catch (Exception e) {e.printStackTrace();}return null;}

 

4、测试

    public static void main(String[] args) {Map<String, String> keyPairs = createKeyPairs();System.out.println("公钥:\n" + keyPairs.get("publicKey"));System.out.println("私钥:\n" + keyPairs.get("privateKey"));if (null != keyPairs) {String encryptMsg = RSAUtils.encryptRSADefault(keyPairs.get("publicKey"), "hello world");System.out.println("加密后的内容:" + encryptMsg);String decryptMsg = RSAUtils.decryptRSADefault(keyPairs.get("privateKey"), encryptMsg);System.out.println("解密后的内容:" + decryptMsg);}

 

输出结果:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/853771.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

升降梯人数识别摄像机

升降梯人数识别摄像机是一种结合摄像技术与智能识别算法的设备,旨在监测升降梯厢内的人数,提供实时准确的人数统计信息。通过安装在升降梯厢内的摄像头,系统可以智能识别厢内的人数,并将数据传输至监控中心或手机APP等平台,帮助管理人员及时了解并控制升降梯的负荷情况。这…

首尔之春(2023)【蓝光原盘 / REMUX】【内封简繁特效字幕】电影百度云/夸克迅雷UC网盘资源链接下载

◎译  名 首尔之春/12.12: The Day/12.12:首尔之春(台) ◎片  名 서울의 봄 ◎年  代 2023 ◎产  地 韩国 ◎类  别 剧情 ◎语  言 韩语 ◎上映日期 2023-11-22(韩国) ◎片  长 141分钟 ◎导  演 金成洙 Sung-su Kim ◎编  剧 金成洙 Sung-su Kim…

多源最短路Floyd算法

多源最短路算法-Floyd 使用Floyd(弗洛伊德)算法,可以以 \(O(n^3)\) 的时间复杂度求出一张多源图的任意两点间的最短路径 一般采用邻接矩阵的方法来存储图: int g[N][N]; g[i][j]其中,g[i][j]的意义为第i个节点到第j个节点的权重 我们需要对邻接矩阵进行路径初始化,将自身…

推荐一款强大的开源物联网 Web 组态软件

前言 快速发展的物联网(IoT)领域,设备管理和监控的需求日益增长。为了满足这一需求并提供更高效的解决方案。 向大家推荐一款强大的开源物联网Web组态软件。这款软件不仅具备灵活的可视化配置功能,还提供了丰富的工具和接口,轻松实现设备集成、数据监控和远程管理。 项目介…

Win10 wsl 迁移到 D 盘

wsl 关闭wsl --shutdown查看系统wsl --list导出 tar 文件wsl --export Ubuntu-24.04 D:/export.tar删除C盘的虚拟机wsl --unregister Ubuntu-24.04导入新的虚拟机wsl --import Ubuntu-24.04 D:\wsl\ D:\export.tar --version 2查看状态直面挑战,躬身入局

PHP源码加密之php-beast

1、简介 php-beast可以对PHP源码文件进行加密,加密后的文件也可以正常的访问。2、安装php-beast# 下载php-beast wget https://github.com/liexusong/php-beast/archive/master.zip# 解压下载的文件 unzip master.zip# 进入解压后的目录 cd php-beast-master# ‌生成配置文件 …

ABB机器人3HAC17332-1电机维修攻略分享

ABB作为工业机器人制造商,其伺服电机是机器人执行精确动作的核心部件。伺服电机负责将电能转化为机械能,驱动机器人的关节和臂部运动。一旦伺服电机出现故障,将直接影响机器人的运行精度和稳定性。一、ABB机器人维修前准备在进行ABB机器人伺服电机维修之前,需要做好以下准备…

大话《权限设计》全篇,领略不同设计模式的魅力

说明该文章是属于OverallAuth2.0系列文章,每周更新一篇该系列文章(从0到1完成系统开发)。该系统文章,我会尽量说的非常详细,做到不管新手、老手都能看懂。说明:OverallAuth2.0 是一个简单、易懂、功能强大的权限+可视化流程管理系统。 友情提醒:本篇文章是属于系列文章,…

LLM应用实战-财经新闻自动聚合

开发了一款新闻资讯的自动聚合的工具,基于crawl4ai框架实现。1. 背景 这段时间项目比较忙,所以本qiang~有些耽误了学习,不过也算是百忙之中,抽取时间来支撑一个读者的需求,即爬取一些财经网站的新闻并自动聚合。 该读者看了之前的《AI资讯的自动聚合及报告生成》文章后,…

减少延迟时间的方法

减少延迟时间的方法 ‍ ​​ ‍一、回顾 重点:延迟时间就是磁头在某一磁道上开转的时间 盘片一直在旋转个不停 机械硬盘的数据读取以一个扇区为单位 物理上相邻的扇区并不能连续读数据,因为磁头读入一个扇区的数据后还需要一小段时间来处理,并不能紧接着读取相邻的扇区的数据…

Win电脑端有什么好用的备忘录便签推荐?

一、sticky notes 中文名叫便笺,就是Windows电脑系统自带的便笺,打开即可直接使用,无需安装。 它是一个一个彩色便利贴形式展现的,可以记录文字、添加图片,适合记录一些简单的信息。 不支持一直悬挂在电脑桌面上显示,也不支持设置提醒时间,想要同步到手机端使用,也有点…

设备的分配与回收

设备的分配与回收 ‍ ​​ ‍一、设备分配时的考虑因素 ​​ (一)设备的固有属性独占设备:一个时段只能分配给一个进程(如打印机) 共享设备:可同时分配给多个进程使用(如磁盘),各进程往往是宏观上同时共享使用设备,而微观上交替使用。 虚拟设备:采用 SPOOLing 技术将…