相关疑难解决方法(0)

使用Java中的RSA私钥加密

我正在尝试使用RSA私钥加密某些内容.

我正在关注这个例子:http: //www.junkheap.net/content/public_key_encryption_java

但将其转换为使用私钥而不是公共密钥.在这个例子之后,我认为我需要做的是:

  • 读入DER格式的私钥
  • 生成PCKS8EncodedKeySpec
  • 从KeyFactory调用generatePrivate()来获取私钥对象
  • 将该私钥对象与Cipher对象一起使用以进行加密

那么,步骤:

密钥是从openssl生成的:

openssl genrsa -aes256 -out private.pem 2048

然后转换为DER格式:

openssl rsa -in private.pem -outform DER -out private.der

我生成PKCS8EncodedKeySpec:

byte[] encodedKey = new byte[(int)inputKeyFile.length()];

try {
    new FileInputStream(inputKeyFile).read(encodedKey);
} catch (FileNotFoundException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
} catch (IOException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
}

PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(encodedKey);
return privateKeySpec;
Run Code Online (Sandbox Code Playgroud)

然后生成私钥对象:

PrivateKey pk = null;

try {
    KeyFactory kf = KeyFactory.getInstance(RSA_METHOD);
    pk = …
Run Code Online (Sandbox Code Playgroud)

java encryption cryptography rsa private-key

10
推荐指数
2
解决办法
3万
查看次数

标签 统计

cryptography ×1

encryption ×1

java ×1

private-key ×1

rsa ×1