栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java非对称加密:存储公钥/私钥的首选方法

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java非对称加密:存储公钥/私钥的首选方法

在我们的应用程序中,我们以DER格式存储公钥和私钥,以便可以在Java外部更轻松地使用和操纵它们。在我们的情况下,私钥上没有密码。

要将私钥转换为在Java中更容易使用的东西:

openssl pkcs8 -topk8 -nocrypt -in key.pem -inform PEM -out key.der -outform DER

然后,您可以通过以下方式直接获取RSA私钥:

public static RSAPrivateKey getPrivateKey(File privateKeyFile) throws IOException, GeneralSecurityException {    byte[] keyBytes = new byte[(int)privateKeyFile.length()];    FileInputStream fis = new FileInputStream(privateKeyFile);    fis.read(keyBytes);    PKCS8EnpredKeySpec spec = new PKCS8EnpredKeySpec(keyBytes);    KeyFactory keyFactory = KeyFactory.getInstance("RSA");    RSAPrivateKey privKey = (RSAPrivateKey) keyFactory.generatePrivate(spec);    return privKey;}

公钥类似于:

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

并阅读:

public static RSAPublicKey getPublicKey(File publicKeyFile) throws IOException, GeneralSecurityException {    byte[] keyBytes = new byte[(int)publicKeyFile.length()];    FileInputStream fis = new FileInputStream(publicKeyFile);    fis.read(keyBytes);    X509EnpredKeySpec publicKeySpec = new X509EnpredKeySpec(keyBytes);    KeyFactory factory = KeyFactory.getInstance("RSA");    RSAPublicKey pubKey = (RSAPublicKey)factory.generatePublic(publicKeySpec);    return pubKey;}

然后很多人存储密钥库。出于我们的目的,我们需要在多个应用程序中以几种不同的语言共享同一密钥,并且不想复制磁盘上的文件。

在这两种情况下,性能都不是一个大问题,因为您可能会将这些密钥存储在某种Singleton或缓存中,而不是每次都重新生成它们。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/470447.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号