java privatekey_java – 从KeyStore传输PrivateKey,在OpenSSL中使用JNI

我有使用WebRTC的

Android应用程序.一切都很完美.但现在,主要问题是加密.

为了拨打电话和转接数据,WebRTC为每次通话创建并使用一个KeyPair.但我想使用AndroidKeyStore中的自定义KayPair.对于这个问题,我需要将自己的KeyPair发送到OpenSSL共享对象才能工作.

修复程序将在NATIVE OpenSSL代码中,其中WebRTC使用此函数获取加密数据的OpenSSL上下文(opensslidnetity.cc):

bool OpenSSLIdentity::ConfigureIdentity

{

...

}

如何将PK从AndroidKeyStore转移到WebRTC本机代码?另一种情况,如何为WebRTC加密设置自定义PK工作?

AndroidKeyStore

在Java中,我可以打开KeyStore(AndroidKeyStore)并获取准备传输的公钥(具有方法的密钥字节 – getEncoded()).此外,我可以获取加密数据的私钥,但我不能以字节为单位发送此密钥,因为getEncoded()返回null.在这种情况下,我想,我可以获得PublicKey abd PrivateKey并将它们保存在bytes数组中.然后,在本机代码中调用准备好的方法.

更新:google.source.chromium中有类似的内容.他们从Android KeyStore获取密钥并在本机代码中创建OpenSSL上下文.用于获取和使用AndroidKeyStore for TLS-Link 1和Link 2的本机类.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用以下代码从.p12文件获取私钥并返回PrivateKey对象: ```java import java.io.FileInputStream; import java.security.KeyStore; import java.security.PrivateKey; import java.security.cert.Certificate; public class KeyStoreExample { public static PrivateKey getPrivateKey(String p12FilePath, String password, String alias, String keyPassword) { try { // 加载.p12文件 FileInputStream fis = new FileInputStream(p12FilePath); KeyStore keyStore = KeyStore.getInstance("PKCS12"); keyStore.load(fis, password.toCharArray()); // 获取私钥 KeyStore.PasswordProtection keyPasswordProtection = new KeyStore.PasswordProtection(keyPassword.toCharArray()); KeyStore.PrivateKeyEntry privateKeyEntry = (KeyStore.PrivateKeyEntry) keyStore.getEntry(alias, keyPasswordProtection); PrivateKey privateKey = privateKeyEntry.getPrivateKey(); return privateKey; } catch (Exception e) { e.printStackTrace(); } return null; } public static void main(String[] args) { String p12FilePath = "path/to/your/file.p12"; String password = "password"; String alias = "alias"; String keyPassword = "keyPassword"; PrivateKey privateKey = getPrivateKey(p12FilePath, password, alias, keyPassword); if (privateKey != null) { System.out.println("私钥: " + privateKey); } } } ``` 在上面的代码,你需要将"path/to/your/file.p12"替换为你实际的.p12文件路径,"password"替换为.p12文件的密码,"alias"替换为私钥的别名,"keyPassword"替换为私钥的密码。运行代码后,你将会得到PrivateKey对象。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值