首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >phpseclib 2 RSA解密工作正常,但是phpseclib 3 RSA解密工作不正常。

phpseclib 2 RSA解密工作正常,但是phpseclib 3 RSA解密工作不正常。
EN

Stack Overflow用户
提问于 2022-07-14 09:03:26
回答 1查看 171关注 0票数 2

phpseclib2样例- working

代码语言:javascript
复制
use phpseclib\Crypt\RSA;
$rsa = new RSA();
$rsa->loadKey($PRIVATE_KEY);
$key = $rsa->decrypt(base64_decode($a));

phpseclib3示例- not working

代码语言:javascript
复制
use phpseclib3\Crypt\PublicKeyLoader;

$private = PublicKeyLoader::load($PRIVATE_KEY);
$key = $private->decrypt(base64_decode($a));
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-07-14 12:19:38

V2和V3默认使用OAEP,但V2使用SHA1作为OAEP和MGF1摘要的默认,而V3使用SHA256 (s. 这里这里)。

因此,为了使与V2一起工作的解密也适用于V3,必须将V3中的摘要显式设置为SHA1:

代码语言:javascript
复制
$decrypted = $private->withHash("sha1")->withMGFHash("sha1")->decrypt(base64_decode($a));

注意,SHA1被认为是不安全的,但是在OAEP上下文中不存在已知的安全问题,有关详细信息,请参阅这里

但是,如果只支持从生态系统中消除SHA256,则没有理由不改用SHA1 (尽可能)。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72977929

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档