PHP 重定向保留脚本


PHP redirect holding up script

>UPDATE

发现了阻碍我脚本的问题。 显然它与解密无关,而是我的重定向。 当我删除此代码块时,脚本开始快速执行。 仍然不确定为什么这会导致问题?

// Make sure we have an Order ID
if( ! isset($_GET['id']) && ! isset($_POST['id']) ) {
    header("Location: https://www.website.com/orders/");
    exit;
}

原始问题:

我一直在使用在这里找到的加密类:加密类。 我将数据存储在MySQL数据库中,使用VARCHAR二进制数据类型(以前我尝试过BLOB和TINYBLOB)。

加密和解密都可以工作,但是解密需要 1 分钟。 加密速度很快。

我想我还应该说这是通过https连接发生的(如果相关的话)。

我不记得解密总是需要这么长时间。 你知道是什么原因造成的吗? 当我注释掉 PHP 代码的解密部分,并只回显加密的字符串时,它会很快执行。

代码

如下注释中要求

class Encryption
{
    const CYPHER = 'blowfish';
    const MODE   = 'cfb';
    const KEY    = 'MyPersonalKey';
    public function encrypt($plaintext)
    {
        $td = mcrypt_module_open(self::CYPHER, '', self::MODE, '');
        $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
        mcrypt_generic_init($td, self::KEY, $iv);
        $crypttext = mcrypt_generic($td, $plaintext);
        mcrypt_generic_deinit($td);
        return $iv.$crypttext;
    }
    public function decrypt($crypttext)
    {
        $plaintext = '';
        $td        = mcrypt_module_open(self::CYPHER, '', self::MODE, '');
        $ivsize    = mcrypt_enc_get_iv_size($td);
        $iv        = substr($crypttext, 0, $ivsize);
        $crypttext = substr($crypttext, $ivsize);
        if ($iv)
        {
            mcrypt_generic_init($td, self::KEY, $iv);
            $plaintext = mdecrypt_generic($td, $crypttext);
        }
        return $plaintext;
    }
}

这是网页上的代码,我在其中设置了 MySQL 行中的变量。 我正在使用WordPress的$wpdb对象。

$order = $wpdb->get_row("SELECT * FROM orders WHERE id = ".$order_id." LIMIT 0,1");
$addons_price =      $order->addons_price;
$hooked_package =    (isset($_GET['hooked_package'])) ? $_GET['hooked_package'] : $order->hooked_package;
$arrival_date_unix = $order->arrival_date_unix;
$order_data =        unserialize($order->order_data);
$preview_total =     $order_data['preview_price'] + $addons_price + $order_data['travel_insurance'];
$normal_total =      $order_data['normal_price'] + $addons_price + $order_data['travel_insurance'];
$package_price =     $order->package_price;
$total_price =       $order->total_price;
$billing_cc =        Encryption::decrypt($order->billing_cc);

另外,这是MySQL类型...

`billing_cc` varbinary(255) DEFAULT NULL

您指示为问题的代码是一个简单的条件重定向。所以它应该与解密没有任何关系。我可以看到重定向缓慢的唯一原因是 Web 服务器负载过重、连接速度慢或存在其他性能问题。