我正在用 Java 编写自己的 RSA 实现,而不使用内置的 Key 接口。我在 PKCS #1 中读到,编码 RSA 密钥的标准方法是使用 DER 格式的 ASN.1。但是,我不确定如何使用我自己的 RSA 版本来做到这一点。这只是一个用于加密和解密文件和文本的程序,仅供个人使用。我不一定要创建 X.509 证书。我只想将编码字符串写入 .txt 文件。我想我应该以某种方式使用 Bouncy Castle。
user7187118
问问题
220 次
1 回答
0
是的,您可以为此使用 Bouncy Castle。
- 下载Bouncy Castle轻量级API源码并编译;
- 创建一个 RSA 密钥对(使用 Bouncy Castle API);
- 通过单步执行 ASN.1 代码来检索“编码”版本。
已经有关于 ASN.1 编码的书籍(和教程),这不是在 StackOverflow 上可以轻松回答的问题。我想您想阅读其中的一些内容,并可能了解 ISO/IEC 8859 规范。
此外,您需要 PKCS#1 标准、X.509 标准(用于 SubjectPublicKeyInfo)和 PKCS#8 来编码私钥的内部结构。
于 2017-02-18T17:56:05.973 回答