-3

我尝试从本地汇款服务中解密使用 PHP 加密的数据。

有PHP示例如下:

<?php

require_once('phpseclib/Crypt/AES.php');


define('API_PASSKEY', 'abcdefghijklmnop');

if($_SERVER['REMOTE_ADDR'] == '203.146.127.115' && isset($_GET['request']))
{
    $aes = new Crypt_AES();
    $aes->setKey(API_PASSKEY);
    $_GET['request'] = base64_decode(strtr($_GET['request'], '-_,', '+/='));
    $_GET['request'] = $aes->decrypt($_GET['request']);
    if($_GET['request'] != false)
    {
        parse_str($_GET['request'],$request);
        $request['Ref1'] = base64_decode($request['Ref1']);

        echo 'SUCCEED';
    }
    else
    {
        echo 'ERROR|INVALID_PASSKEY';
    }
}
else
{
    echo 'ERROR|ACCESS_DENIED';
}
?>

但是,我想用 C# 进行解密。

我还设置了简单的 PHP 加密文本进行测试,但也无法使用 C# 解密。

<?php 
include('phpseclib/Crypt/AES.php');

$aes = new Crypt_AES();

$aes->setKey('abcdefghijklmnop');

$plaintext = 'Hello';

$cryptoText = $aes->encrypt($plaintext) ;

$cryptoText =  base64_encode( $cryptoText);

echo $cryptoText . "<br/>";

echo $aes->decrypt(base64_decode($cryptoText));


?>

我期待着得到你的好建议。

4

1 回答 1

0

phpseclib 默认使用 CBC,启用 PKCS#7 填充和 128 位密钥(如果有帮助的话)。

于 2012-06-23T15:48:14.350 回答