Magento OnePage Checkout中的下订单失败

时间:2011-09-03 12:17:26

标签: php ajax magento

我有一个Magento商店,它已被转换为“一次一个交易”类型商店,结账过程中断。我一直试图调试这个,但是已经碰壁了,主要是因为我对Magento的理解有限。

在saveOrder步骤中,点击“下订单”时,页面显示“提交订单信息,然后消息清除,购物者仍在订单审核页面上。

我已经使用Firebug和HttpFox进行了分析,我可以看到订单信息正在发送

(Request-Line)  POST /checkout/onepage/saveOrder/ HTTP/1.1
Host    www.domainname.com
User-Agent  Mozilla/5.0 (Windows NT 6.0; rv:2.0) Gecko/20100101 Firefox/4.0
Accept  text/javascript, text/html, application/xml, text/xml, */*
Accept-Language en-us,en;q=0.5
Accept-Encoding gzip, deflate
Accept-Charset  ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive  115
Connection  keep-alive
X-Requested-With    XMLHttpRequest
X-Prototype-Version 1.6.0.3
Content-Type    application/x-www-form-urlencoded; charset=UTF-8
Referer https://www.domainname.com/checkout/onepage/
Content-Length  178
Cookie  frontend=cd60252d28cd115d4096cb2bb5b6a043
Pragma  no-cache
Cache-Control   no-cache

发布数据显示了所有必需的信息:

payment[method] authorizenet
payment[cc_type]    VI
payment[cc_number]  4111111111111111
payment[cc_exp_month]   5
payment[cc_exp_year]    2012
payment[cc_cid] 987

我的问题似乎与这篇文章类似: http://fishpig.co.uk/magento-tutorials/magento-checkout-error-undefined-javascript-alert

但是我没有收到“未定义”警告,所以我在下面添加了“else”语句:

nextStep: function(transport){
    if (transport && transport.responseText) {
            alert(transport.responseText);
        try{
            response = eval('(' + transport.responseText + ')');
        }
        catch (e) {
            response = {};
        }
        if (response.redirect) {
            location.href = response.redirect;
            return;
        }
        if (response.success) {
            this.isSuccess = true;
            window.location=this.successUrl;
        }
        else{
            var msg = response.error_messages;
            if (typeof(msg)=='object') {
                msg = msg.join("\n");
            }
            alert(msg);
        }

        if (response.update_section) {
            $('checkout-'+response.update_section.name+'-load').update(response.update_section.html);
            response.update_section.html.evalScripts();
        }

        if (response.goto_section) {
            checkout.gotoSection(response.goto_section);
            checkout.reloadProgressBlock();
        }
    } else {
        alert('transport.responseText');
        }
},

我收到没有文字的JS警报,所以看起来transport.reponseText是空的。我发现的空响应文本的主要参考似乎与同源策略有关,我认为这不适用,因为我的AJAX帖子来自www.domainname.com。

当我直接在浏览器中调用saveOrder函数时,我收到了一个有效的回复:

https://www.domainname.com/checkout/onepage/saveOrder {“success”:false,“error”:true,“error_messages”:“信用卡号码与信用卡类型不匹配”}

和HTTPFox显示我从Ajax调用得到200响应,但responsetext只是空的。我发现Magento的例外日志中没有PHP错误或错误。我发现的唯一可能与Magento系统日志中的“已发送标题”有关:

</pre>
2011-09-03T12:14:21+00:00 DEBUG (7): HEADERS ALREADY SENT: <pre>[0] wwwroot/app/code/core/Mage/Core/Controller/Response/Http.php:50
[1] wwwroot/lib/Zend/Controller/Response/Abstract.php:726
[2] wwwroot/app/code/core/Mage/Core/Controller/Response/Http.php:82
[3] wwwroot/app/code/core/Mage/Core/Controller/Varien/Front.php:169
[4] wwwroot/app/Mage.php:459
[5] wwwroot/index.php:67
</pre>

有没有人有任何建议为什么responseText会变回空?

1 个答案:

答案 0 :(得分:1)

自定义模块有问题。禁用Magento管理员中的所有自定义模块实际上并不禁用它们,它只是“禁用它们的输出”。

在模块配置中设置False解决了无效标头错误,此时我能够调试导致AJAX检出错误的自定义模块问题。