【发布时间】:2012-11-01 20:13:31
【问题描述】:
直到最近,当我们开始改用 PHP 时,我们公司主要使用 vbscript。在尝试将 SagePay 表单工具包集成到我们的一个项目中时,我遇到了这个障碍。
我们在 Windows 2008 服务器上,这无法更改。服务器不包含 mcrypt 库,我们的服务器主机不会安装它,因为它是一个共享平台。
有问题的行来自您用来通过 SagePay 支付费用的 SagePay 表单工具包。希望你们中的一些人会熟悉这些。
有问题的行是:
//** perform encryption with PHP's MCRYPT module
$strCrypt = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $strEncryptionPassword, $strIn, MCRYPT_MODE_CBC, $strIV);
这是一个更大的加密函数的一部分,如下所示:
//** Wrapper function do encrypt an encode based on strEncryptionType setting **
function encryptAndEncode($strIn) {
global $strEncryptionType
,$strEncryptionPassword;
if ($strEncryptionType=="XOR")
{
//** XOR encryption with Base64 encoding **
return base64Encode(simpleXor($strIn,$strEncryptionPassword));
}
else
{
//** AES encryption, CBC blocking with PKCS5 padding then HEX encoding - DEFAULT **
//** use initialization vector (IV) set from $strEncryptionPassword
$strIV = $strEncryptionPassword;
//** add PKCS5 padding to the text to be encypted
$strIn = addPKCS5Padding($strIn);
//** perform encryption with PHP's MCRYPT module
$strCrypt = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $strEncryptionPassword, $strIn, MCRYPT_MODE_CBC, $strIV);
//** perform hex encoding and return
return "@" . bin2hex($strCrypt);
}
}
有谁知道我可以如何绕过这个问题,或者我可以实现一个等效的库来代替它吗?任何指向正确方向的指针、提示或点将不胜感激。
编辑好的,所以在研究了更多之后,据我了解,我只需要一个 128 位 AES 加密功能,而不使用 mcrypt。
【问题讨论】:
-
'我们公司主要使用 vbscript 直到最近才开始改用 PHP' - 从坏到坏,或煎锅到火(更清楚严重性)。
-
总比站着被炸好。
-
我认为他们俩都烧得很糟糕......
-
我感觉到一个 .net 精英... :p
-
一点也不,我使用 VB/VBA 多年,甚至在适当的时候勇敢地使用 PHP(公共部门的东西通常需要它)。我使用 PHP,我对它的厌恶仅仅来自经验,而不是我对任何其他语言或技术的偏爱。如果我被视为做出诸如“.NET 好,PHP 不好”之类的错误判断,我会质疑我对自己无知的认识。
标签: php encryption mcrypt opayo