关于RSA加密算法的工具类
关于RSA加密算法的工具类
最近在捣鼓SSO(单点登录),就是一个在应用(系统)登录之后,当切换其他应用(系统)的时候,可以省去登录,提高用户的使用的便捷。(具体有时间在写)
期间涉及的安全问题,发送数据涉及账户密码以及分布系统之间的信息安全问题。
- package test.rsa;
- import java.io.*;
- import java.math.BigInteger;
- import java.security.*;
- import java.security.interfaces.*;
- import java.security.spec.*;
- import javax.crypto.*;
- import org.bouncycastle.util.encoders.Hex;
- import sun.misc.*;
- public class TestRSA {
- /**
- * * 生成密钥对 *
- *
- * @return KeyPair *
- * @throws EncryptException
- */
- public static KeyPair generateKeyPair() throws Exception {
- try {
- KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance("RSA",
- new org.bouncycastle.jce.provider.BouncyCastleProvider());
- final int KEY_SIZE = 1024;// 块加密的大小,是不要太大,否则效率会低
- keyPairGen.initialize(KEY_SIZE, new SecureRandom());
- KeyPair keyPair = keyPairGen.generateKeyPair();
- saveKeyPair(keyPair);
- return keyPair;
- } catch (Exception e) {
- throw new Exception(e.getMessage());
- }
- }
- public static KeyPair getKeyPair() throws Exception {
- FileInputStream fis = new FileInputStream(
- "D:/javasoft/TempTest/RSAKey.txt");
- ObjectInputStream oos = new ObjectInputStream(fis);
- KeyPair kp = (KeyPair) oos.readObject();
- oos.close();
- fis.close();
- return kp;
- }
- public static void saveKeyPair(KeyPair kp) throws Exception {
- FileOutputStream fos = new FileOutputStream(
- "D:/javasoft/TempTest/RSAKey.txt");
- ObjectOutputStream oos = new ObjectOutputStream(fos);
- // 生成密钥
- oos.writeObject(kp);
- oos.close();
- fos.close();
- }
- /**
- * * 生成公钥 *
- *
- * @param modulus *
- * @param publicExponent *
- * @return RSAPublicKey *
- * @throws Exception
- */
- public static RSAPublicKey generateRSAPublicKey(byte[] modulus,
- byte[] publicExponent) throws Exception {
- KeyFactory keyFac = null;
- try {
- keyFac = KeyFactory.getInstance("RSA",
- new org.bouncycastle.jce.provider.BouncyCastleProvider());
- } catch (NoSuchAlgorithmException ex) {
- throw new Exception(ex.getMessage());
- }
- RSAPublicKeySpec pubKeySpec = new RSAPublicKeySpec(new BigInteger(
- modulus), new BigInteger(publicExponent));
- try {
- return (RSAPublicKey) keyFac.generatePublic(pubKeySpec);
- } catch (InvalidKeySpecException ex) {
- throw new Exception(ex.getMessage());
- }
- }
- /**
- * * 生成私钥 *
- *
- * @param modulus *
- * @param privateExponent *
- * @return RSAPrivateKey *
- * @throws Exception
- */
- public static RSAPrivateKey generateRSAPrivateKey(byte[] modulus,
- byte[] privateExponent) throws Exception {
- KeyFactory keyFac = null;
- try {
- keyFac = KeyFactory.getInstance("RSA",
- new org.bouncycastle.jce.provider.BouncyCastleProvider());
- } catch (NoSuchAlgorithmException ex) {
- throw new Exception(ex.getMessage());
- }
- RSAPrivateKeySpec priKeySpec = new RSAPrivateKeySpec(new BigInteger(
- modulus), new BigInteger(privateExponent));
- try {
- return (RSAPrivateKey) keyFac.generatePrivate(priKeySpec);
- } catch (InvalidKeySpecException ex) {
- throw new Exception(ex.getMessage());
- }
- }
- /**
- * 加密的方法
- * @throws IOException
- * @throws NoSuchPaddingException
- * @throws NoSuchAlgorithmException
- */
- private static String encrypt(PublicKey pk,String source) throws Exception{
- Cipher cipher = Cipher.getInstance("RSA",new org.bouncycastle.jce.provider.BouncyCastleProvider());
- cipher.init(Cipher.ENCRYPT_MODE, pk);
- byte[] sbt = source.getBytes();
- byte[] epByte = cipher.doFinal(sbt);
- BASE64Encoder encoder = new BASE64Encoder();
- String epStr = encoder.encode(epByte);
- return epStr;
- }
- private static String encrypt1(PublicKey pk,String source) throws Exception{
- Cipher cipher = Cipher.getInstance("RSA",new org.bouncycastle.jce.provider.BouncyCastleProvider());
- cipher.init(Cipher.ENCRYPT_MODE, pk);
- byte[] s = source.getBytes();
- byte[] en_s = cipher.doFinal(s);
- return new String(Hex.encode(en_s));
- }
- /**
- * 解密的方法
- * @throws Exception
- */
- public static String decrypt(PrivateKey pk,String source) throws Exception {
- /** 得到Cipher对象对已用公钥加密的数据进行RSA解密 */
- Cipher cipher = Cipher.getInstance("RSA",new org.bouncycastle.jce.provider.BouncyCastleProvider());
- cipher.init(Cipher.DECRYPT_MODE, pk);
- BASE64Decoder decoder = new BASE64Decoder();
- byte[] b1 = decoder.decodeBuffer(source);
- /** 执行解密操作 */
- byte[] b = cipher.doFinal(b1);
- return new String(b);
- }
- public static String decrypt1(PrivateKey pk,String source) throws Exception {
- /** 得到Cipher对象对已用公钥加密的数据进行RSA解密 */
- Cipher cipher = Cipher.getInstance("RSA",new org.bouncycastle.jce.provider.BouncyCastleProvider());
- cipher.init(Cipher.DECRYPT_MODE, pk);
- /** 执行解密操作 */
- byte[] b = cipher.doFinal(Hex.decode(source));
- return new String(b);
- }
- public static void main(String[] args) throws Exception {
- String s = "1-Test-我";
- String en_s = encrypt1(getKeyPair().getPublic(), s);
- System.out.println("----------------分割线--------------------------");
- System.out.println("加密之后:");
- System.out.println(en_s);
- System.out.println("----------------分割线--------------------------");
- String de_s = decrypt1(getKeyPair().getPrivate(),en_s);
- System.out.println("还原密文:");
- System.out.println(de_s);
- }
- }
关于RSA加密算法的工具类的更多相关文章
- RSA加解密工具类RSAUtils.java,实现公钥加密私钥解密和私钥解密公钥解密
package com.geostar.gfstack.cas.util; import org.apache.commons.codec.binary.Base64; import javax.cr ...
- RSA和AES工具类
AESUtil import com.xxx.common.BssException; import com.xxx.common.constants.CommonConstants; import ...
- AES/DES 可逆性加密算法 -- java工具类
package com.lock.demo.service; import org.apache.tomcat.util.codec.binary.Base64; import javax.crypt ...
- Java中的RSA加解密工具类:RSAUtils
本人手写已测试,大家可以参考使用 package com.mirana.frame.utils.encrypt; import com.mirana.frame.utils.log.LogUtils; ...
- 可用的 .net core 支持 RSA 私钥加密工具类
首先说明 MS并不建议私钥加密,而且.net 于安全的考虑,RSACryptoServiceProvider类解密时只有同时拥有公钥和私钥才可以,原因是公钥是公开的,会被多人持有,这样的数据传输是不安 ...
- Android工具类整合
Android-JSONUtil工具类 常用的Json工具类,包含Json转换成实体.实体转json字符串.list集合转换成json.数组转换成json public class JSONUtil ...
- JAVA的RSA加密算法工具类
须要用到一个jar http://www.bouncycastle.org/latest_releases.html 须要注意的问题 JS用同一秘钥生成的密文用java解密出来是逆序的,即js加密12 ...
- Asp.Net 常用工具类之加密——非对称加密RSA算法
踏入程序员这个行业也有几年了,几年中有收获(技术加强),有付出(时间和亚健康状态).当然喏,并不后悔,代码路还长!!! On The Way,永不止步!!! 开发过程中也积累了一些自己的经验.代码块和 ...
- java 加密工具类(MD5、RSA、AES等加密方式)
1.加密工具类encryption MD5加密 import org.apache.commons.codec.digest.DigestUtils; /** * MD5加密组件 * * @autho ...
随机推荐
- 《嵌入式Linux开发实用教程》
<嵌入式Linux开发实用教程> 基本信息 作者: 朱兆祺 李强 袁晋蓉 出版社:人民邮电出版社 ISBN:9787115334831 上架时间:2014-2-13 出版日期: ...
- idea创建springcloud项目图文教程(EurekaServer注册中心)
http://blog.csdn.net/hcmony/article/details/77854999 idea创建springcloud项目图文教程(EurekaServer注册中心)(六) 1, ...
- Git项目的初始化
快速设置— 如果你知道该怎么操作,直接使用下面的地址 git@github.com:username/myproject.git 我们强烈建议所有的git仓库都有一个README, LICENSE, ...
- [转]应用RSACryptoServiceProvider类轻松实现RSA算法
在我们现实当中经常会存在需要对某些数据进行加密保护 然后进行解密的操作,比方,我们需要对某些XML配置信息里面的某些数据进行加密,以防止任何人打开该XML配置信息都能正常的看到该配置信息里面的内容,从 ...
- Windows7安装CodeTyphon
WARNING 1: On windows (XP, Vista and Win7), you must install this software as user with administrato ...
- [leetcode]Restore IP Addresses @ Python
原题地址:https://oj.leetcode.com/problems/restore-ip-addresses/ 题意: Given a string containing only digit ...
- IIS通过HTML5实现应用程序缓存的离线浏览
这里我是使用的IIS7: IIS7发布了网站后要想使用HTML5的应用程序缓存,需要增加一个关于文本/缓存清单( text/cache-manifest)的新的MIME类型,选中网站添加一个MIME类 ...
- 自动化打包 Jenkins 持续集成 Git Gradle MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- centos 下 mysql+keepalived实现双主自由切换
目录 ip规划 mysql双主配置 keepalived配置 mysql1中keepalived的配置 mysql2中keepalived的配置 VIP漂移检测 本文的目的是搭建一个互为主从的mysq ...
- eclipse如何debug调试jdk源码,并显示局部变量
http://blog.csdn.net/xuefeng0707/article/details/8738869 http://blog.csdn.net/leehsiao/article/detai ...