我有一个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会变回空?
答案 0 :(得分:1)
自定义模块有问题。禁用Magento管理员中的所有自定义模块实际上并不禁用它们,它只是“禁用它们的输出”。
在模块配置中设置False解决了无效标头错误,此时我能够调试导致AJAX检出错误的自定义模块问题。