`

RSA

阅读更多
package net.shopxx.util.ccb.sample;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.PrivateKey;
import java.security.PublicKey;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;

/**
 * 
 * @author suzh
 * 
 * 2006-8-21
 *
 * 生成密钥的方法
 */
public class GenerateKey
{

	public GenerateKey()
	{

	}

	/**
	 * 生成RSA密钥对
	 * 
	 * @param pub
	 * @param pri
	 */
	public void generRSAKey(String pub, String pri)
	{

		FileOutputStream output = null;

		try
		{
			KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
			// 密钥的长度
			kpg.initialize(1024);

			KeyPair kp = kpg.genKeyPair();

			PublicKey pbkey = kp.getPublic();

			PrivateKey prkey = kp.getPrivate();

			// 保存公钥

			output = new FileOutputStream(pub);

			output.write(ConvertBase64.encodeBase64(pbkey.getEncoded()));

			output.close();
			// 保存私钥
			output = new FileOutputStream(pri);

			output.write(ConvertBase64.encodeBase64(prkey.getEncoded()));

		} catch (Exception e)
		{
			e.printStackTrace();
		} finally
		{
			try
			{
				if (output != null)
				{
					output.close();
				}
			} catch (Exception e)
			{
				e.printStackTrace();
			}
		}

	}

	/**
	 * 生成对称算法的密钥对象
	 * 
	 * @param filepath
	 *            文件路径
	 * @return
	 */
	public void generSecretKey(String secret)
	{

		FileOutputStream output = null;

		try
		{
			output = new FileOutputStream(secret);

			KeyGenerator kg = KeyGenerator.getInstance("DESede");
			// 密钥的长度
			kg.init(112);

			SecretKey secretKey = kg.generateKey();

			output.write(ConvertBase64.encodeBase64(secretKey.getEncoded()));

		} catch (Exception e)
		{
			e.printStackTrace();
		}

		finally
		{
			try
			{
				if (output != null)
					output.close();
			} catch (Exception e)
			{
				e.printStackTrace();
			}
		}

	}

	/**
	 * 
	 * @param args
	 */
	public static void main(String[] args)
	{
		GenerateKey gener = new GenerateKey();
		
		//非对称密钥对
		gener.generRSAKey("D:/test/商户正式RSA/key_RSA_pub.dat","D:/test/商户正式RSA/key_RSA_priv.dat");
		FileInputStream input = null;
		try {
			input = new FileInputStream(new File("D:/test/商户正式RSA/key_RSA_pub.dat"));
			byte[] p_data = new byte[input.available()];
			input.read(p_data);
			input.close();
			System.out.println("str:"+new String(p_data));
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		//对称密钥
		gener.generSecretKey("D:/test/商户正式RSA/DES_key.dat");
	}

}

 

分享到:
评论

相关推荐

    Delphi RSA 加密解密签名验签控件 RSA_Component(1.0.0.0).rar

    RSA加密演算法是一种非对称加密演算法。在公开密钥加密和电子商业中RSA被广泛使用。 典型的应用 1. 苹果App签名, iOS App 签名的原理; 2. 支付宝签名验证 ; 2. HTTPS 加密连接; 3. 程序直接用RSA+AES加密通信 ...

    RSA加密解密(C#)实现

    RSA加密解密C#实现调用实例 public string RSAEncrypt(string xmlPublicKey, string m_strEncryptString) { try { byte[] PlainTextBArray; byte[] CypherTextBArray; string Result; System.Security....

    微信小程序RSA公钥加密模块

    (去掉注释13.6kb)微信小程序RSA加密模块,用法请参考文件里面的注释。 //加载RSA模块 var RSA = require('rsa.js'); var rsa_res = new RSA.RSAKey(); //配置公钥证书 let public_n = ''; let public_e = ''; ...

    rsa加密算法(Delphi实现).zip

    RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest)、阿迪·萨莫尔(Adi Shamir)和伦纳德·阿德曼(Leonard Adleman)一起提出的。1987年首次公布,当时他们三人都在麻省理工学院工作。RSA就是他们三人姓氏...

    RSA.rar_RSA算法_寻找大素数 rsa_数论算法_简单数论

    RSA算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但是想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥。RSA算法是第一个能同时用于加密和数字签名的算法,也易于理解和操作。...

    JavaScript_RSA加解密+分段加解密.zip

    使用RSA非对称加密完成JavaScript前端RSA加密和分段加解密,最近研究了RSA非对称加密,关于什么是RSA,网上各种文章一搜一大把,但是关于如何使用RSA完成前端的组合加密解密,东西就非常少了,并且由于RSA的特性,一...

    RSA实验代码与文档

     1、了解和掌握RSA加密算法原理及过程;  2、了解生成大素数的方法;  3、掌握快速指数算法;  4、能够编写代码实现RSA算法。 【实验内容】  1、编写程序构造一RSA密钥;  2、编写程序实现快速指数算法;  3...

    C# 实现与JAVA互通 加签/验签,RSA加密/解密

    * RSA加密解密:私钥解密,公钥加密。 * RSA数字签名-俗称加签验签:私钥加签,公钥验签。  * RSA加密解密:私钥解密,公钥加密。 * RSA数字签名-俗称加签验签:私钥加签,公钥验签。  * RSA加密解密:私钥...

    RSA算法演示RSA算法演示

    RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示RSA算法演示

    Springboot项目报文加密(采用AES、RSA动态加密策略)

    Springboot项目报文加密(采用AES、RSA动态加密策略) Springboot项目报文加密(采用AES、RSA动态加密策略) Springboot项目报文加密(采用AES、RSA动态加密策略) Springboot项目报文加密(采用AES、RSA动态加密...

    RSA签名验签工具windows_V1.4.zip_rsa_rsa2生成签名_rsa签名工具_工具_验签

    支付宝签名、验签、RSA、RSA2公钥、私钥一键生成等工具

    PKCS #1: RSA Cryptography Specifications Version 2.2

    PKCS #1: RSA Cryptography Specifications Version 2.2 Table of Contents 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 4 1.1. Requirements Language . . . . . . . . . . . . . . . . . ...

    基于OpenSSL的RSA加解密的C语言实现

    1.该程序是基于OpenSSL的使用纯C语言来实现RSA加解密的,在Linux环境下开发完成,建议在Linux环境下使用(在Windows环境下需要自行修改); 2.该程序具有生成RSA密钥对、RSA公钥加密和RSA私钥解密的功能,支持手动...

    pb_rsa.zip_PB做加密解密_RSA PB_pb 加密_rsa pb_rsa加密

    用PowerBuilder实现RSA加密算法

    与Java的RSA加解密兼容的Python加解密库m2crypto(Windows下免编译)

    由于Java的RSA加解密一般都是用RSA/ECB/PKCS1PADDING,导致Python一般的RSA加密库的加解密结果与Java的不兼容,Python下目前能与之兼容的RSA的库目前发现的只有一个,就是m2crypto。 这个库目前的问题是在windows...

    spring-security-rsa-1.0.10.RELEASE-API文档-中文版.zip

    赠送jar包:spring-security-rsa-1.0.10.RELEASE.jar; 赠送原API文档:spring-security-rsa-1.0.10.RELEASE-javadoc.jar; 赠送源代码:spring-security-rsa-1.0.10.RELEASE-sources.jar; 赠送Maven依赖信息文件:...

    rsa2048.rar RSA2048的C语言实现代码

    rsa2048.rar RSA2048的C语言实现代码rsa2048.rar RSA2048的C语言实现代码

    c#写的rsa类 解密加密 js密码RSA 的密钥产生

    1.RSACryption RSA 的密钥产生 2.RSACryption RSA的加密函数 3.RSACryption RSA的解密函数 4.RSACryption 获取Hash描述表 5.RSACryption RSA签名 6.RSACryption RSA签名认证 / <summary> /// RSA加密...

    C#RSA加密解密签名和验证签名的小例子

    C#RSA加密解密签名和验证签名的小例子,代码都加了注释,可以很容易看懂.如果应用到消息收发,发送方用公钥加密,接收方用私钥解密.如果是应用到软件注册方面,则需要客户端保留公钥,程序开发者保留私钥.使用签名和验证...

    RSA和RSA2签名算法区别.md

    MarkDown文档,使用表格形式展示了RSA签名算法和RSA2签名算法的区别,是一篇阐明概念的文档

Global site tag (gtag.js) - Google Analytics