rsa加密(一)

本文介绍了如何使用Openssl在Ubuntu上生成1024位的RSA私钥和公钥,包括查看密钥、PKCS#8编码私钥的步骤,并提供了验证密钥对正确性的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文借鉴于http://blog.youkuaiyun.com/chaijunkun/article/details/7275632的博客

第一步:使用Openssl生成私钥跟公钥

 由于笔者使用阿里云服务器ubuntu 16.04,自带Openssl,跳过

输入命令:openssl version -a   查询是否安装Openssl


生成1024位私钥:openssl genrsa -out rsa_private_key.pem 1024


查看生成的私钥:cat rsa_private_key.pem


根据私钥生成公钥:openssl rsa -in rsa_private_key.pem -out rsa_public_key.pem -pubout


查看生成的公钥:cat rsa_public_key.pem


私钥进行PKCS#8编码:openssl pkcs8 -topk8 -in rsa_private_key.pem -out pkcs8_rsa_private_key.pem -nocrypt


查看编码后的PKCS#8私钥:cat pkcs8_rsa_private_key.pem


验证秘钥对是否正确的代码如下:

package com.koow.test;


import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.X509EncodedKeySpec;
import java.security.KeyPairGenerator;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.io.BufferedReader;
import java.io.IOException;
import java.security.InvalidKeyException;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.io.InputStream;
import java.io.InputStreamReader;
import sun.misc.BASE64Decoder;
import java.security.spec.PKCS8EncodedKeySpec;


import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.NoSuchPaddingException;


public class RSAEncrypt {


	private static final String DEFAULT_PUBLIC_KEY = ""
			+ "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDDYMpmCWDPx6S36L"
			+ "F7N53I/7SyuCwZoSQYEbXvQzo4uX3Q1vA9ADKqNlriSpcThoWKQ4JD"
			+ "JUcFJn3rwS05TOPdNx3CIL4zT/x/XG369o9/Vzm"
			+ "7dBBcPcPvEJxm+c+oOVydwGz5NvrROXOwVmYQfm"
			+ "3Z/9LL6CfDzmR4wLFz16/OswIDAQAB";
	private static final String DEFAULT_PRIVATE_KEY = ""
			+ "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAMNgymY"
			+ "JYM/HpLfosXs3ncj/tLK4LBmhJBgRte9DOji5fdDW8D0AMqo2WuJKlx"
			+ "OGhYpDgkMlRwUmfevBLTlM
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值