首页 > 解决方案 > 无法使用 phpseclib 创建 Crypt_RSA 实例

问题描述

我正在尝试使用我需要与之交互的供应商提供给我的模数和指数来加密一串数据。我的研究使我找到了 phpseclib 库,以使这很容易做到。

我使用 composer ( php composer.phar require phpseclib/phpseclib:~3.0 )安装了最新版本的 phpseclib (3.0)并将其放在 PHP 包含路径 ( /var/Classes ) 中已经存在的目录下。

我阅读的所有文档以及如何执行此操作的示例都产生了如下所示的代码。但是,在尝试创建 Crypt_RSA 实例时,简单测试在第 5 行失败。

<?php
require 'vendor/autoload.php';
$modulus  = 'somevalue';
$exponent = 'ZZZZ';
$rsa      = new Crypt_RSA();
$modulus  = new Math_BigInteger(base64_decode($modulus), 256);
$exponent = new Math_BigInteger(base64_decode($exponent), 256);
$rsa->loadKey(['n' => $modulus, 'e' => $exponent]);
echo $rsa;

完整的错误信息是:

致命错误:未捕获的错误:在 test.php:5 中找不到类“Crypt_RSA”

SO 上和其他地方都有许多资源描述了实现此目的的各种方法,但它们似乎都不是 phpseclib 3.0 版兼容/相关的。

标签: phpcryptographyphpseclibphpseclib3

解决方案


好吧,对于版本 3 API,情况有很大不同。下面的代码按预期工作。

<?php
require 'vendor/autoload.php';
use phpseclib3\Crypt\PublicKeyLoader;
use phpseclib3\Math\BigInteger;
$modulus  = 'somevalue';
$exponent = 'ZZZZ';
$modulus  = new BigInteger(base64_decode($modulus), 256);
$exponent = new BigInteger(base64_decode($exponent), 256);
$rsa = PublicKeyLoader::load([
    'n' => $modulus,
    'e' => $exponent
]);
echo $rsa;

推荐阅读