RSAsecurity.java
package com.mstf.rsa; import java.security.KeyFactory;import java.security.KeyPair;import java.security.KeyPairGenerator;import java.security.PrivateKey;import java.security.PublicKey;import java.security.interfaces.RSAPrivateKey;import java.security.interfaces.RSAPublicKey;import java.security.spec.PKCS8EncodedKeySpec;import java.security.spec.X509EncodedKeySpec; import javax.crypto.Cipher; import com.sun.org.apache.xerces.internal.impl.dv.util.Base64; public class RSAsecurity { public static String src = "admin"; public void priENpubDE() { try { // 初始化秘钥 KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA"); // 秘钥长度 keyPairGenerator.initialize(1024); // 初始化秘钥对 KeyPair keyPair = keyPairGenerator.generateKeyPair(); // 公钥 RSAPublicKey rsaPublicKey = (RSAPublicKey) keyPair.getPublic(); // 私钥 RSAPrivateKey rsaPrivateKey = (RSAPrivateKey) keyPair.getPrivate(); // 2.私钥加密,公钥解密----加密 // 生成私钥 PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(rsaPrivateKey.getEncoded()); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec); // Cipher类为加密和解密提供密码功能,通过getinstance实例化对象 Cipher cipher = Cipher.getInstance("RSA"); // 初始化加密 cipher.init(Cipher.ENCRYPT_MODE, privateKey); byte[] result = cipher.doFinal(src.getBytes()); System.out.println("私钥加密,公钥解密----加密:" + Base64.encode(result)); // 3.私钥加密,公钥解密----解密 // 生成公钥 X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(rsaPublicKey.getEncoded()); keyFactory = KeyFactory.getInstance("RSA"); PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec); cipher = Cipher.getInstance("RSA"); // 初始化解密 cipher.init(Cipher.DECRYPT_MODE, publicKey); result = cipher.doFinal(result); System.out.println("私钥加密,公钥解密----解密:" + new String(result)); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } public void pubENpriDE() { try { // 1.初始化秘钥 KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA"); // 秘钥长度 keyPairGenerator.initialize(512); // 初始化秘钥对 KeyPair keyPair = keyPairGenerator.generateKeyPair(); // 公钥 RSAPublicKey rsaPublicKey = (RSAPublicKey) keyPair.getPublic(); // 私钥 RSAPrivateKey rsaPrivateKey = (RSAPrivateKey) keyPair.getPrivate(); // 2.公钥加密,私钥解密----加密 X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(rsaPublicKey.getEncoded()); KeyFactory keyFactory = KeyFactory.getInstance("RSA"); PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec); // 初始化加密 // Cipher类为加密和解密提供密码功能,通过getinstance实例化对象 Cipher cipher = Cipher.getInstance("RSA"); cipher.init(Cipher.ENCRYPT_MODE, publicKey); // 加密字符串 byte[] result = cipher.doFinal(src.getBytes()); System.out.println("公钥加密,私钥解密----加密:" + Base64.encode(result)); // 3.公钥加密,私钥解密-----解密 PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(rsaPrivateKey.getEncoded()); keyFactory = KeyFactory.getInstance("RSA"); PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec); // 初始化解密 cipher.init(Cipher.DECRYPT_MODE, privateKey); // 解密字符串 result = cipher.doFinal(result); System.out.println("公钥加密,私钥解密-----解密:" + new String(result)); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } }}
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
软考中级精品资料免费领
- 历年真题答案解析
- 备考技巧名师总结
- 高频考点精准押题
- 资料下载
- 历年真题
193.9 KB下载数265
191.63 KB下载数245
143.91 KB下载数1148
183.71 KB下载数642
644.84 KB下载数2756
相关文章
发现更多好内容- 如何在 Java 中实现对正方形的缩放操作?(如何在Java中对正方形进行缩放操作)
- 如何正确使用 Java 的 join 方法?(java join方法怎么使用)
- Java 中 DecimalFormat 在哪些场景下使用较为合适?(Java DecimalFormat在哪里使用合适)
- 如何确保Redis客户端的安全性:实用技巧与最佳实践
- 在 JavaScript 中如何使用 parentNode?(javascript中的parentNode怎么用)
- 如何高效编码 Java Supplier 接口?(java supplier接口的高效编码技巧)
- 如何进行 Java NoSQL 查询优化?(java nosql查询优化怎样进行)
- Java 中 `equals()` 的核心究竟是什么?(java eques的核心是什么)
- Java代理模式的优缺点分别有哪些?(Java代理模式有哪些优缺点)
- 2024下半年北京软考成绩复查时间及流程
猜你喜欢
AI推送时光机RSA加密的方式和解密方式实现方法(推荐)
后端开发2023-05-31
RSA加密实现之JAVA方式
后端开发2023-09-28
Flutter RSA加密解密的方法
后端开发2023-06-30
利用Python实现RSA加密解密方法实例
后端开发2024-04-02
vue前端RSA加密java后端解密的方法实现
后端开发2023-02-24
Java RSA加密解密实现方法分析【附BASE64 jar包下载】
后端开发2023-05-30
Base64加解密的实现方式实例详解
后端开发2023-05-31
C#实现简单的文件加密与解密方式
后端开发2023-01-28
C语言实现SM4加解密方式
后端开发2023-05-18
SM2加密实现之JAVA方式
后端开发2023-09-06
密码系统AES私钥RSA公钥加解密的方法
后端开发2023-06-29
SpringSecurity如何实现升级密码加密方式详解
后端开发2023-01-04
java项目中的非对称加密怎么利用RSA方式实现
后端开发2023-05-31
Java C++实现相同MD5加密算法的方式
后端开发2024-04-02
mysql数据库的加密与解密方式
后端开发2024-04-02
Python实现栅栏密码的加密解密方法详解
后端开发2023-01-16
Java AES加密解密的简单实现方法
后端开发2023-05-31
数据加密和解密原理以及实现方法
后端开发2024-04-18
JavaScript常规加密技术实现方式详解
后端开发2023-05-16
对python实现加密的方式有哪些
后端开发2024-04-02
咦!没有更多了?去看看其它编程学习网 内容吧