RSA公私钥加解密方式-工具类

直接上代码

​
import java.io.ByteArrayOutputStream;
import java.math.BigInteger;
import java.security.*;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import java.security.spec.PKCS8EncodedKeySpec;
import java.security.spec.X509EncodedKeySpec;
import java.util.HashMap;
import java.util.Map;
import javax.crypto.Cipher;
import org.apache.commons.codec.binary.Base64;
/*** @author yao* @create 2018/1/20*/
public class RSAEncrypt {private static final String ALGORITHM = "RSA";private static final int MAX_ENCRYPT_BLOCK = 117;private static final int MAX_DECRYPT_BLOCK = 128;private static Map<Integer, String> keyMap = new HashMap<Integer, String>();  //用于封装随机产生的公钥与私钥public static final Integer PUBLICKEY = 0;//0表示公钥public static final Integer PRIVATEKEY = 1;//1表示私钥public RSAEncrypt() {}/*** 公钥加密* @param str 明文参数* @param publicKey 公钥* @return* @throws Exception*/public static String encryptPublic(String str, String publicKey) throws Exception {byte[] decoded = Base64.decodeBase64(publicKey);RSAPublicKey pubKey = (RSAPublicKey)KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(decoded));Cipher cipher = getCipher(1, pubKey);return splitEncrypt(str, cipher, pubKey.getModulus());}/*** 私钥加密* @param str 明文参数* @param privateKey 私钥* @return* @throws Exception*/public static String encryptPrivate(String str, String privateKey) throws Exception {byte[] decoded = Base64.decodeBase64(privateKey);RSAPrivateKey priKey = (RSAPrivateKey)KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(decoded));Cipher cipher = getCipher(1, priKey);return splitEncrypt(str, cipher, priKey.getModulus());}/*** 公钥解密* @param str  密文参数* @param publicKey 公钥* @return* @throws Exception*/public static String decryptPublic(String str, String publicKey) throws Exception {byte[] inputByte = Base64.decodeBase64(str.getBytes("UTF-8"));byte[] decoded = Base64.decodeBase64(publicKey);RSAPublicKey pubKey = (RSAPublicKey)KeyFactory.getInstance("RSA").generatePublic(new X509EncodedKeySpec(decoded));Cipher cipher = getCipher(2, pubKey);return splitDecrypt(str, cipher, pubKey.getModulus());}/*** 私钥解密* @param str  密文参数* @param privateKey 私钥* @return* @throws Exception*/public static String decryptPrivate(String str, String privateKey) throws Exception {byte[] inputByte = Base64.decodeBase64(str.getBytes("UTF-8"));byte[] decoded = Base64.decodeBase64(privateKey);RSAPrivateKey priKey = (RSAPrivateKey)KeyFactory.getInstance("RSA").generatePrivate(new PKCS8EncodedKeySpec(decoded));Cipher cipher = getCipher(2, priKey);return splitDecrypt(str, cipher, priKey.getModulus());}private static String splitDecrypt(String str, Cipher cipher, BigInteger modulus) throws Exception {byte[] bytes = Base64.decodeBase64(str);int inputLen = bytes.length;int offLen = 0;int i = 0;ByteArrayOutputStream byteArrayOutputStream;byte[] cache;for(byteArrayOutputStream = new ByteArrayOutputStream(); inputLen - offLen > 0; offLen = 128 * i) {if (inputLen - offLen > 128) {cache = cipher.doFinal(bytes, offLen, 128);} else {cache = cipher.doFinal(bytes, offLen, inputLen - offLen);}byteArrayOutputStream.write(cache);++i;}byteArrayOutputStream.close();cache = byteArrayOutputStream.toByteArray();return new String(cache);}private static Cipher getCipher(int model, Key key) throws Exception {Cipher cipher = Cipher.getInstance("RSA");cipher.init(model, key);return cipher;}private static String splitEncrypt(String str, Cipher cipher, BigInteger modulus) throws Exception {byte[] bytes = str.getBytes();int inputLen = bytes.length;int offLen = 0;int i = 0;ByteArrayOutputStream bops;byte[] cache;for(bops = new ByteArrayOutputStream(); inputLen - offLen > 0; offLen = 117 * i) {if (inputLen - offLen > 117) {cache = cipher.doFinal(bytes, offLen, 117);} else {cache = cipher.doFinal(bytes, offLen, inputLen - offLen);}bops.write(cache);++i;}bops.close();cache = bops.toByteArray();String encodeToString = Base64.encodeBase64String(cache);return encodeToString;}/*** 随机生成密钥对* @throws NoSuchAlgorithmException*/public static void genKeyPair() throws NoSuchAlgorithmException {// KeyPairGenerator类用于生成公钥和私钥对,基于RSA算法生成对象KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA");// 初始化密钥对生成器,密钥大小为96-1024位keyPairGen.initialize(1024,new SecureRandom());// 生成一个密钥对,保存在keyPair中KeyPair keyPair = keyPairGen.generateKeyPair();RSAPrivateKey privateKey = (RSAPrivateKey) keyPair.getPrivate();   // 得到私钥RSAPublicKey publicKey = (RSAPublicKey) keyPair.getPublic();  // 得到公钥String publicKeyString = new String(Base64.encodeBase64(publicKey.getEncoded()));// 得到私钥字符串String privateKeyString = new String(Base64.encodeBase64((privateKey.getEncoded())));// 将公钥和私钥保存到MapkeyMap.put(PUBLICKEY ,publicKeyString); keyMap.put(PRIVATEKEY ,privateKeyString); }public static void main(String[] args) throws Exception {//参数String str = "{\"test\":\"001\"}";System.out.println("参数:" + str);//随机生成密钥对genKeyPair();//公钥加密System.out.println("公钥:" + keyMap.get(PUBLICKEY));System.out.println("私钥:" + keyMap.get(PRIVATEKEY));String encrypt = RSAEncrypt.encryptPublic(str, keyMap.get(PUBLICKEY));System.out.println("公钥加密:" + encrypt);//私钥解密String decrypt = RSAEncrypt.decryptPrivate(encrypt, keyMap.get(PRIVATEKEY));System.out.println("私钥解密:" + decrypt);//私钥加密String encryptPrivate = RSAEncrypt.encryptPrivate(str, keyMap.get(PRIVATEKEY));System.out.println("私钥加密:" + encryptPrivate);//公钥解密String decryptPublic = RSAEncrypt.decryptPublic(encryptPrivate, keyMap.get(PUBLICKEY));System.out.println("公钥解密:" + decryptPublic);}
}​

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

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

相关文章

UML之用例图(use case)箭头方向

1、Association&#xff0c;无箭头&#xff0c;Actor连接UseCase即可&#xff1b; 2、DirectedAssocition&#xff0c;Actor连接UseCase&#xff0c;箭头由Actor指向UseCase&#xff08;角色指向用例&#xff09;&#xff1b; 3、Generalization&#xff0c;继承&#xff0c;…

MD5加密方式-工具类

import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.security.MessageDigest;/*** Md5加密方法* * author */ public class Md5Utils {private static final Logger log LoggerFactory.getLogger(Md5Utils.class);private static byte[] md5(String s){Mes…

UML-记忆技巧

箭头方向 UML箭头方向&#xff1a;从子类指向父类&#xff0c;读作继承自定义子类时需要通过extend关键字指定父类子类一定时知道父类定义的&#xff0c;但父类并不知道子类的定义 只有知道对方信息时才能指向对方 image.png 实现-继承|虚线-实现 空心三角箭头&#xff1…

动态定时任务数据库获取方式

Spring 中&#xff0c;创建定时任务除了使用Scheduled 注解外&#xff0c;还可以使用 SchedulingConfigurer。 Schedule 注解有一个缺点&#xff0c;其定时的时间不能动态的改变&#xff0c;而基于 SchedulingConfigurer 接口的方式可以做到。SchedulingConfigurer 接口可以实…

国密算法SM2,SM3,SM4-java实现

SM2是国家密码管理局于2010年12月17日发布的椭圆曲线公钥密码算法&#xff0c;基于ECC。其签名速度与秘钥生成速度都快于RSA&#xff0c;非对称加密&#xff0c;该算法已公开 SM3是中华人民共和国政府采用的一种密码散列函数标准&#xff0c;由国家密码管理局于2010年12月17日…

数据库事务隔离级别-- 脏读、幻读、不可重复读(清晰解释)

一、数据库事务隔离级别 数据库事务的隔离级别有4个&#xff0c;由低到高依次为Read uncommitted 、Read committed 、Repeatable read 、Serializable &#xff0c;这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。 √: 可能出现 : 不会出现 脏读不可重复读幻…

国密算法SM2-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> 工具类 import java.math.BigInteger;public class Util {/*** 整形转换成网络…

原子性和一致性的区别是什么?

注&#xff1a; 重度参考了&#xff1a;https://www.zhihu.com/question/30272728/answer/72476703&#xff08;讲的非常好&#xff0c;逻辑清晰&#xff09; 轻度参考了&#xff1a;https://www.cnblogs.com/fjdingsd/p/5273008.html&#xff08;概念也比较清晰&#xff0c;…

国密算法SM3-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> SM3Utils import org.bouncycastle.crypto.digests.SM3Digest; import org.b…

什么是事务、事务特性、事务隔离级别、spring事务传播特性

1.什么是事务&#xff1a; 事务是指程序中的一个操作序列。其特点是&#xff1a;该序列的所有操作要么全部成功完成&#xff0c;要么只要有一个操作失败&#xff0c;则该序列所有操作都将被撤销。这也是事务的原子性&#xff08;要么成功&#xff0c;要么失败&#xff09;。 …

国密算法SM4-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> SM4 import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputS…

软件工程 – 开发模型

软件工程 – 开发模型 为了指导软件开发&#xff0c;可以用不同的方式将软件生命周期中的所有开发活动组织组织起来从而形成不同的开发模型。 瀑布模式 瀑布模型严格遵守软件生命周期各阶段的固定顺序:计划、分析、设计、编程、测试和维护&#xff0c;上一阶段完成才能进入到…

Microsoft.CSharp.dll程序集的作用

《C#与.NET 4高级程序设计:第5版》第18章动态类型和动态语言运行时&#xff0c;本章&#xff0c;我们将学习dynamic关键字的方方面面&#xff0c;理解如何使用DLR &#xff08;Dynamic Language Runtime&#xff0c;动态语言运行时&#xff09;将松散的类型映射到正确的内存对象…

排序算法之选择排序

动图演示 使用场景:适用于大多数排序,数据量大效率明显优于冒泡 java代码实现 import java.util.Arrays;/*** 选择排序*/ public class SelectSort {private static int[] selectSort(int[] arr) {if (arrnull||arr.length<2){return arr;}//控制循环次数,最后一个元素不用…

VS的包含目录、库目录、引用目录、可执行目录解释

来源&#xff1a;包含目录、库目录、附加包含目录、附加库目录、附加依赖项之详解 学习备份 VS项目中的包含目录、库目录、附加包含目录、附加库目录、附加依赖项均在”项目->属性->配置属性”下进行配置&#xff0c;具体说明如下&#xff1a; VC目录&#xff1a; 包含目…

排序算法之插入排序

动图演示 使用场景:数据有序程度越高,效率越高 java代码实现 import java.util.Arrays;/*** 插入排序*/ public class InsertSort {private static int[] insertSort(int[] arr) {if (arrnull||arr.length<2){return arr;}// 从下标为1的元素开始选择合适的位置插入&…

第一节:复习委托,并且通过委托的异步调用开启一个新线程和异步回调、异步等待。

一. 再谈委托 1. 委托是一个关键字为delegate的自定义类型&#xff0c;通过委托可以把方法以参数的形式传递给另外一个方法&#xff0c;实现插件式的开发模式&#xff1b; 同时调用委托的时候&#xff0c;委托所包含的所有方法都会被实现。 2. 委托的发展历史&#xff1a;new…

ArrayList和LinkedList 的区别

ArrayList: 非线程安全的集合,基于动态数组, 查询快,因为ArrayList直接通过数组下标直接找到元素 增删慢(非极端情况),新增和删除元素时可能需要扩容和复制数组 LinkedList : 非线程安全的集合,基于双向链表 增删快,新增和删除元素时,只需要改变对象的引用即可 查询慢,查…

第二节:深入剖析Thread的五大方法、数据槽、内存栅栏。

一. Thread及其五大方法 Thread是.Net最早的多线程处理方式&#xff0c;它出现在.Net1.0时代&#xff0c;虽然现在已逐渐被微软所抛弃&#xff0c;微软强烈推荐使用Task(后面章节介绍)&#xff0c;但从多线程完整性的角度上来说&#xff0c;我们有必要了解下N年前多线程的是怎么…

HashMap和ConcurrentHashMap

HashMap: 线程不安全&#xff0c;不支持并发操作&#xff0c;键-值&#xff08;key-value&#xff09;都允许为空、、不保证有序 在 JDK1.7 中&#xff0c;HashMap 采用头插法插入元素&#xff0c;因此并发情况下会导致环形链表&#xff0c;产生死循环。 虽然 JDK1.8 采用了…