在我正在构建的一个使用直接邮政作为付款方式的网站中 Authorize.net 我遇到了一个问题,即成功完成订单后购物车不会被停用。在Mage_Authorizenet_Model_Directpost,我能够确认作为订单授权步骤的一部分,第 574 行的报价正在被停用。
Mage::getModel('sales/quote')
->load($order->getQuoteId())
->setIsActive(false)
->save();
但是,在 directpost.js 中,当 Authorize.net 加载 IFrame 并调用 returnQuote 函数时,它会重定向到 Mage_Authorizenet_Directpost_PaymentController 的 returnQuoteAction,该函数调用 _returnCustomerQuote 函数。
if ($order->getId()) {
$quote = Mage::getModel('sales/quote')
->load($order->getQuoteId());
if ($quote->getId()) {
$quote->setIsActive(1)
->setReservedOrderId(NULL)
->save();
$this->_getCheckout()->replaceQuote($quote);
}
$this->_getDirectPostSession()->removeCheckoutOrderIncrementId($incrementId);
$this->_getDirectPostSession()->unsetData('quote_id');
if ($cancelOrder) {
$order->registerCancellation($errorMsg)->save();
}
}
请注意,报价再次设置为活动。我不知道他们为什么要这样做,除非订单被取消。我在想也许我在这里的逻辑中遗漏了一些东西。我们已经对实际订单提交进行了一些单页结帐自定义和一些自定义,但我没有看到任何会影响这一点的东西。Magento是否期望报价稍后会在调用链中被禁用?我很难调试它,因为我无法逐步完成代码,因为 Direct Post 不会将响应中继回我的本地 Authorize.net。
感谢您可以提供的任何帮助。
我所知,如果来自 Authorize.net 的请求参数包含错误消息,即使成功,看起来也可以调用_returnCustomerQuote。这是来自Mage_Authorizenet_Directpost_PaymentController的重定向操作
if (!empty($redirectParams['success'])
&& isset($redirectParams['x_invoice_num'])
&& isset($redirectParams['controller_action_name'])
) {
$this->_getDirectPostSession()->unsetData('quote_id');
$params['redirect_parent'] = Mage::helper('authorizenet')->getSuccessOrderUrl($redirectParams);
}
if (!empty($redirectParams['error_msg'])) {
$cancelOrder = empty($redirectParams['x_invoice_num']);
$this->_returnCustomerQuote($cancelOrder, $redirectParams['error_msg']);
}
但是,我可以通过查看访问权限来判断我的情况.log[组合]有一个条目来自/checkout/onepage
将要/authorizenet/directpost_payment/returnQuote
。
在拉了一会儿头发并挖掘代码并进行一些研究之后,我觉得这只能是 loadIframe 函数中的一个错误,该函数绑定到 directpost 中的 onLoadIframe .js。
loadIframe : function() {
if (this.paymentRequestSent) {
switch (this.controller) {
case 'onepage':
this.paymentRequestSent = false;
if (!this.hasError) {
this.returnQuote();
}
break;
case 'sales_order_edit':
case 'sales_order_create':
if (!this.orderRequestSent) {
this.paymentRequestSent = false;
if (!this.hasError) {
this.returnQuote();
} else {
this.changeInputOptions('disabled', false);
toggleSelectsUnderBlock($('loading-mask'), true);
$('loading-mask').hide();
enableElements('save');
}
}
break;
}
if (this.tmpForm) {
document.body.removeChild(this.tmpForm);
}
}
},
在我看来,它正在检查当重定向操作填充 iframe 时是否发送了付款请求。如果付款请求已发送,如果它使用的是单页控制器,并且响应中没有错误,则返回报价,从而使其保持活动状态,并且商品仍保留在购物车中...
这对我来说没有意义,所以我从this.hasError中删除了爆炸。现在下单后购物车被清零了,我似乎没有任何其他问题
现在看起来像这样,我希望有人告诉我我错了(认真的)。
loadIframe : function() {
if (this.paymentRequestSent) {
switch (this.controller) {
case 'onepage':
this.paymentRequestSent = false;
if (this.hasError) {
this.returnQuote();
}
break;
case 'sales_order_edit':
case 'sales_order_create':
if (!this.orderRequestSent) {
this.paymentRequestSent = false;
if (!this.hasError) {
this.returnQuote();
} else {
this.changeInputOptions('disabled', false);
toggleSelectsUnderBlock($('loading-mask'), true);
$('loading-mask').hide();
enableElements('save');
}
}
break;
}
if (this.tmpForm) {
document.body.removeChild(this.tmpForm);
}
}
},
似乎这在"sales_order_create"控制器的情况下,但我现在不理会 Magento。