Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/233.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP重定向挂起脚本_Php_Redirect - Fatal编程技术网

PHP重定向挂起脚本

PHP重定向挂起脚本,php,redirect,Php,Redirect,更新 我发现了阻碍我剧本的问题。显然这与解密无关,而是我的重定向。当我删除这段代码时,脚本开始快速运行。仍然不确定这是为什么导致问题 // Make sure we have an Order ID if( ! isset($_GET['id']) && ! isset($_POST['id']) ) { header("Location: https://www.website.com/orders/"); exit; } 原始问题: 我一直在使用此处找到的加

更新

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

// 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服务器负载重、连接速度慢或存在其他性能问题。

能否向我们展示一些代码,特别是“解密”过程前后的几行代码?尝试添加并移动“die('stopped on line x')”在decrypt函数的每一行上的语句。将其向下移动到函数中,直到您准确地分离出哪个mcrypt调用较慢。我看不出该类中有任何问题,您是否有一个很长的键?这可能是导致解密速度慢的一个因素。密钥长度为15个字符。我认为延迟实际上发生在脚本的其他地方,而不是在解密阶段。我会继续发帖的。是的,很抱歉搞混了。我明白代码的意思。然而,我发现解密毕竟不是延迟的原因。一旦我删除了重定向代码块,脚本就运行得很快。不知道为什么。