[PHP] RSA加解密篇

简介

RSA算法属于非对称加密算法,非对称加密算法需要两个秘钥:公开密钥(publickey)和私有秘钥(privatekey).公开密钥和私有秘钥是一对,如果公开密钥对数据进行加密,只有用对应的私有秘钥才能解密;如果私有秘钥对数据进行加密那么只有用对应的公开密钥才能解密.因为加密解密使用的是两个不同的秘钥,所以这种算法叫做非对称加密算法.简单的说就是公钥加密私钥解密,私钥加密公钥解密

获取公私钥

通过读取文件获取RSA公开密钥(publickey)和私有秘钥(privatekey)。

if (!function_exists('RsaEncrypt')){
    function RsaEncrypt($data,$source = 'client')
    {
        $path = base_path();
        $rsa = new \App\Libraries\RSAUtil(file_get_contents($path.'/'.$source.'public.txt'),file_get_contents($path.'/'.$source.'private.txt'));
        return $rsa->publicEncrypt($data);
    }
}
if (!function_exists('RsaDecrypt')){
    function RsaDecrypt($data,$source = 'client')
    {
        $path = base_path();
        $rsa = new \App\Libraries\RSAUtil(file_get_contents($path.'/'.$source.'public.txt'),file_get_contents($path.'/'.$source.'private.txt'));
        return $rsa->privDecrypt($data);
    }
}
使用公钥加密
/**
     * 公钥加密
     * @param string $data
     * @return null|string
     */
    public function publicEncrypt($data = '')
    {
        if (!is_string($data)) {
            return null;
        }
        $RSA_ENCRYPT_BLOCK_SIZE = 245;

        $result = '';
        $split = str_split($data, $RSA_ENCRYPT_BLOCK_SIZE);
        foreach ($split as $block) {
            openssl_public_encrypt($block, $dataEncrypt, $this->getPublicKey(), OPENSSL_PKCS1_PADDING);
            $result .= $dataEncrypt;
//            echo "||block||".$block;
//            echo "||dataEncrypt||".$dataEncrypt;
        }
        if ($result) {
            return $result;
        } else {
            return false;
        }
    }

使用私钥加密

**
     * 私钥加密
     * @param string $data
     * @return null|string
     */
    public function privEncrypt($data = '')
    {
        if (!is_string($data)) {
            return null;
        }

//        return openssl_private_encrypt($data,$encrypted,$this->getPrivateKey()) ? base64_encode($encrypted) : null;

        $RSA_ENCRYPT_BLOCK_SIZE = 245;
        $result = '';
        $split = str_split($data, $RSA_ENCRYPT_BLOCK_SIZE);
        foreach ($split as $block) {
            openssl_private_encrypt($block, $dataEncrypt, $this->getPrivateKey(), OPENSSL_PKCS1_PADDING);
            $result .= $dataEncrypt;
        }
        if ($result) {
            return $result;
        } else {
            return false;
        }
    }

使用私钥解密

**
     * 私钥解密
     * @param string $encrypted
     * @return null
     */
    public function privDecrypt($encrypted = '')
    {
        if (!is_string($encrypted)) {
            return null;
        }
//        return (openssl_private_decrypt(base64_decode($encrypted), $decrypted, $this->getPrivateKey())) ? $decrypted : null;
        $RSA_ENCRYPT_BLOCK_SIZE = 256;
        $result = '';
        $split = str_split($encrypted, $RSA_ENCRYPT_BLOCK_SIZE);
        foreach ($split as $block) {
            openssl_private_decrypt($block, $dataEncrypt, $this->getPrivateKey(), OPENSSL_PKCS1_PADDING);
            $result .= $dataEncrypt;
        }
        if ($result) {
            return $result;
        } else {
            return false;
        }
    }

公钥解密

/**
     * 公钥解密
     * @param string $encrypted
     * @return null
     */
    public function publicDecrypt($encrypted = '')
    {
        if (!is_string($encrypted)) {
            return null;
        }

//        return (openssl_public_decrypt(base64_decode($encrypted), $decrypted, $this->getPublicKey())) ? $decrypted : null;
        $RSA_ENCRYPT_BLOCK_SIZE = 256;
        $result = '';
        $split = str_split($encrypted, $RSA_ENCRYPT_BLOCK_SIZE);
        foreach ($split as $block) {
            openssl_public_decrypt($block, $dataEncrypt, $this->getPublicKey(), OPENSSL_PKCS1_PADDING);
            $result .= $dataEncrypt;
        }
        if ($result) {
            return $result;
        } else {
            return false;
        }
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,那我来给你简单地介绍一下 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` 是解密后的原文字符串。 希望这个简单的例子能够帮到你。如果有任何问题,欢迎继续提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值