java与php rsa加密互通

原创
2018/12/26 11:06
阅读数 1.3K

第三方提供的java rsa秘钥(pkcs8格式),PHP不能直接使用;只能将rsa秘钥转成pkcs1格式。然后再按照PHP rsa秘钥格式处理,每64个字符进行换行处理。

先转成pkcs1格式,用支付宝转换工具;传送门

代码如下:

function format_secret_key($secret_key, $type){
   // 64个英文字符后接换行符"\n",最后再接换行符"\n"
   $key = (wordwrap($secret_key, 64, "\n", true))."\n";
   // 添加pem格式头和尾
   if ($type == 'pub') {
      $pem_key = "-----BEGIN PUBLIC KEY-----\n" . $key . "-----END PUBLIC KEY-----\n";
   }else if ($type == 'pri') {
      $pem_key = "-----BEGIN RSA PRIVATE KEY-----\n" . $key . "-----END RSA PRIVATE KEY-----\n";
   }else{
      echo('公私钥类型非法');
      exit();
   }
   return $pem_key;
}

这样就生成PHP能用的rsa秘钥啦

按照java接口指定的加密方式选择相应的选项

public function sign($data = '') {
   if (empty($data)){
      return false;
   }
   $private_key = $this->getPrivateKey();
   $private_key = $this->format_secret_key($private_key,'pri');
   if (empty($private_key)){
      echo "Private Key error!";
      return false;
   }
   $pkeyid = openssl_get_privatekey($private_key);
   if (empty($pkeyid)){
      echo "private key resource identifier False!";
      return false;
   }
   $verify = openssl_sign($data,$signature,$pkeyid,OPENSSL_ALGO_MD5);
   openssl_free_key($pkeyid);
   return $verify ? base64_encode($signature) : false;
}

这样就完成了

展开阅读全文
加载中

作者的其它热门文章

打赏
0
0 收藏
分享
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部