微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP重定向阻止脚本

UPDATE

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

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

原始问题:

我一直在使用这里找到的加密类:Encryption class.我将数据存储在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,'');
        $ivsize    = mcrypt_enc_get_iv_size($td);
        $iv        = substr($crypttext,$ivsize);
        $crypttext = substr($crypttext,$ivsize);
        if ($iv)
        {
            mcrypt_generic_init($td,$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服务器负载很重,连接速度很慢或者存在其他一些性能问题.

原文地址:https://www.jb51.cc/php/137213.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐