php网页rsa加密效率低,PHP进行RSA加密解密

最近在着手写一个服务端安全接口规范,需要用到RSA加密解密。所以小试牛刀一下,并且做个记录。

环境:   Win7 64位

PHP 5.6.12

需要原型工具:

OpenSSL下载地址:http://slproweb.com/products/Win32OpenSSL.html

一、安装OpenSSL

随意安装到哪里

二、CMD中进入到OpenSLL的bin目录下进行私钥和公钥的生成

//生成私钥

openssl genrsa -out rsa_private_key.pem 1024

//生成公钥

openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

将生产的私钥、公钥拷贝到你的PHP项目中

二-PS、在Win下面使用生成私钥的时候遇到一个BUG:

错误:

WARNING: can't open config file: /usr/local/ssl/openssl.cnf

Loading 'screen' into random state - done

Generating RSA private key, 1024 bit long modulus

.........++++++

.........................................++++++

unable to write 'random state'

e is 65537 (0x10001)

解决办法:

在CMD中进行如下操作

set OPENSSL_CONF=c:\OpenSSL-Win32\bin\openssl.cfg

三、开启PHP的OpenSSL扩展

将php.ini中的extension=php_openssl.dll开启(去掉;)

四、PHP加密解密练习

/*

* RSA加密解密

*

* @auther  ken<695093513@qq.com>

* @time    2015-10-13

*/

namespace App\Models;

class RsaCrypt {

const PRIVATE_KEY_FILE_PATH = 'app\Certificate\rsa_private_key.pem';

const PUBLIC_KEY_FILE_PATH = 'app\Certificate\rsa_public_key.pem';

/**

* Rsa加密

* @param string $orignData

* @return string

*/

public static function encode($orignData) {

//密钥文件的路径

$privateKeyFilePath = self::PRIVATE_KEY_FILE_PATH;

extension_loaded('openssl') or die('php需要openssl扩展支持');

(file_exists($privateKeyFilePath)) or die('密钥的文件路径不正确');

//生成Resource类型的密钥,如果密钥文件内容被破坏,openssl_pkey_get_private函数返回false

$privateKey = openssl_pkey_get_private(file_get_contents($privateKeyFilePath));

($privateKey) or die('密钥不可用');

//加密以后的数据,用于在网路上传输

$encryptData = '';

///用私钥加密

if (openssl_private_encrypt($orignData, $encryptData, $privateKey)) {

return $encryptData;

} else {

die('加密失败');

}

}

/**

* Rsa解密

* @param string $encryptData

* @return string

*/

public static function decode($encryptData) {

//公钥文件的路径

$publicKeyFilePath = self::PUBLIC_KEY_FILE_PATH;

extension_loaded('openssl') or die('php需要openssl扩展支持');

(file_exists($publicKeyFilePath)) or die('公钥的文件路径不正确');

//生成Resource类型的公钥,如果公钥文件内容被破坏,openssl_pkey_get_public函数返回false

$publicKey = openssl_pkey_get_public(file_get_contents($publicKeyFilePath));

($publicKey) or die('公钥不可用');

//解密以后的数据

$decryptData = '';

///用公钥解密

if (openssl_public_decrypt($encryptData, $decryptData, $publicKey)) {

return $decryptData;

} else {

die('解密失败');

}

}

}

  • 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、付费专栏及课程。

余额充值