PHP rsa加解密方法

 private function rsa_enc_des($aesKey,$cert_key,$flag){
        /*$flag 1加密  2解密*/
        if($flag==1){
            $cert_public_path=$cert_key;
            $public_key = openssl_pkey_get_public(file_get_contents($cert_public_path));
            openssl_public_encrypt($aesKey,$encAesKey,$public_key);
            framework_static_function::write_log('返回参数加密后【aesKey】:'.$encAesKey,'caimaoInfo');
            $res=base64_encode($encAesKey);
        }elseif($flag==2){
            $cert_private_path=$cert_key;
            $private_key = openssl_pkey_get_private(file_get_contents($cert_private_path));
            openssl_private_decrypt(base64_decode($aesKey),$merchantAESKey,$private_key);
            framework_static_function::write_log('入参解密后明文【16位随机数】:'.$merchantAESKey,'caimaoInfo');
            $res=$merchantAESKey;
        }
        return $res;
    }
    /*rsa加解密*/
    public function rsa_enc_des($aesKey,$flag){
        /*$flag 1加密  2解密*/
        if($flag==1){
            $encrypted = "";
            $cert_public_path=$this->hna_key;
            $public_key = openssl_pkey_get_public(file_get_contents($cert_public_path));
            foreach (str_split($aesKey, 117) as $chunk) {
                openssl_public_encrypt($chunk,$encryptData,$public_key);
                $encrypted .= $encryptData;
            }
            $res=base64_encode($encrypted);
        }elseif($flag==2){
            $decrypted = '';
            $cert_private_path=$this->mer_key;
            $private_key = openssl_pkey_get_private(file_get_contents($cert_private_path));
            foreach (str_split(base64_decode($aesKey), 128) as $chunk) {
                openssl_private_decrypt($chunk, $decryptData, $private_key);
                $decrypted .= $decryptData;
            }
            $res=$decryptData;
        }
        return $res;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,那我来给你简单地介绍一下 Vue 中使用 jsrsasign 进行 RSA 加密,以及 PHP 中如何使用 jsrsasign 进行 RSA 解密的方法。 首先,你需要在 Vue 项目中安装 jsrsasign 库。可以通过 npm 安装: ``` npm install --save jsrsasign ``` 接下来,在 Vue 组件中引入 jsrsasign 库: ```js import * as jsrsasign from 'jsrsasign'; ``` 然后,你可以使用 jsrsasign 库中的 RSA 加密方法进行加密: ```js const publicKey = "-----BEGIN PUBLIC KEY-----\nMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxWq8GIV2n8B0vzgW/9f0\n9f8sokUeMv2kEX0VtL0X+gP+3Z6z8gfk1C0yRd4XnFqT+qfQexJgNQ+6N0lR5t57\nU0BuK7pM6hBcG/auDnTJH5k1ElL6wZaZP3ZwI+o9uZp4t9N4z0QFpQ/2kQGvN9Kv\n/y5Gc0kjM+Lw6J8QHbS3WbiH+OfkD6TwHs3Sv3XrQux6OvD4lSfJtA5pxzXs7pcq\n5X1EaVQq1Gd/5yG9vNzK4+Yx+2j5hJ3bhfJ+o7bLZieVUAyjy3DkGnBfrtD+LQ+3\n2wX8A2ZVd5H/3T3Kd+JyXpVxwX1m8lO5+Ih3vz5IbJfT9dAJWS5jQbT1t6w3OzQ\n1QIDAQAB\n-----END PUBLIC KEY-----"; const encrypt = (text) => { const publicKeyObj = jsrsasign.KEYUTIL.getKey(publicKey); const encrypted = jsrsasign.KJUR.crypto.Cipher.encrypt(text, publicKeyObj); return jsrsasign.hextob64(encrypted); }; ``` 这里的 `publicKey` 是你的 RSA 公钥字符串, `encrypt` 方法用于加密传入的文本。 接下来,我们来看看在 PHP 中如何使用 jsrsasign 进行 RSA 解密。首先,你需要在 PHP 项目中引入 jsrsasign 库: ```php require_once('jsrsasign.php'); ``` 然后,你可以使用 jsrsasign 库中的 RSA 解密方法进行解密: ```php use \phpseclib\Crypt\RSA; $privateKey = "-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQD9r0L2CpkLq0XJ\n..."; $ciphertext = "..."; $rsa = new RSA(); $rsa->loadKey($privateKey); $plaintext = $rsa->decrypt(jsrsasign\ASN1::hex2bin($ciphertext)); ``` 这里的 `privateKey` 是你的 RSA 私钥字符串, `ciphertext` 是加密后的密文字符串。`plaintext` 是解密后的原文字符串。 希望这个简单的例子能够帮到你。如果有任何问题,欢迎继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值