ios rsa php,php openssl生成的rsa密钥给android和ios使用注意哪些问题?

有一个项目需要php通过openssl 生产rsa蜜月供android和ios使用。目前已经调试两天了,android那边使用密钥的时候一直有问题。

X509EncodedKeySpec expects DER-encoded data, not PEM-encoded

这个是android遇到的其中一个报错信息

下面是我的生成密钥的代码

// generate 2048-bit RSA key

$config = array(

'private_key_bits' => $length,

'private_key_type' => OPENSSL_KEYTYPE_RSA

);

$pkGenerate = openssl_pkey_new($config);

// get the private key

openssl_pkey_export($pkGenerate,$pkGeneratePrivate); // NOTE: second argument is passed by reference

// get the public key

$pkGenerateDetails = openssl_pkey_get_details($pkGenerate);

$pkGeneratePublic = $pkGenerateDetails['key'];

// free resources

openssl_pkey_free($pkGenerate);

// fetch/import public key from PEM formatted string

// remember $pkGeneratePrivate now is PEM formatted...

// this is an alternative method from the public retrieval in previous

$pkImport = openssl_pkey_get_private($pkGeneratePrivate); // import

$pkImportDetails = openssl_pkey_get_details($pkImport); // same as getting the public key in previous

$pkImportPublic = $pkImportDetails['key'];

openssl_pkey_free($pkImport); // clean up

return array('public'=>$pkGeneratePublic,'private'=>$pkGeneratePrivate);

之前对rsa加密没什么了解,今天是第一次使用,又遇到这个跨语言的问题。我自己是可以使用生成的密钥进行加密和解密的。

请了解相关问题的人指点一下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值