第三方提供的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;}
这样就完成了