本文借鉴于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