解决magento中guest页面cookie保存时间过短问题

    在magento新的企业版11,有个新的功能退货(RMA),不仅能退货,还能以guest的身份查看订单的各种信息,但在IE下有个问题:cookies的保存时间太短了,如果需要使用到需要验证权限的操作,就会重定向到 sales/guest/form/ 页面。

       查看关键代码,发现跳转是发生在 Mage_Sales_Helper_Guest 类中


[php] view plain copy
  1. class Mage_Sales_Helper_Guest extends Mage_Core_Helper_Dat  
  2. {  
  3.     /** 
  4.      * Cookie params 
  5.      */  
  6.     protected $_cookieName  = 'guest-view';  
  7.     protected $_lifeTime    = 600;  
  8.   
  9.     /** 
  10.      * Try to load valid order by $_POST or $_COOKIE 
  11.      * 
  12.      * @return bool|null 
  13.      */  
  14.     public function loadValidOrder()  
  15.     {  
  16.         if (Mage::getSingleton('customer/session')->isLoggedIn()) {  
  17.             Mage::app()->getResponse()->setRedirect(Mage::getUrl('sales/order/history'));  
  18.             return false;  
  19.         }  
  20.   
  21.         $post = Mage::app()->getRequest()->getPost();  
  22.   
  23.         $type           = '';  
  24.         $incrementId    = '';  
  25.         $lastName       = '';  
  26.         $email          = '';  
  27.         $zip            = '';  
  28.         $protectCode    = '';  
  29.         $errors         = false;  
  30.   
  31.         /** @var $order Mage_Sales_Model_Order */  
  32.         $order = Mage::getModel('sales/order');  
  33.   
  34.         if (empty($post) && !Mage::getSingleton('core/cookie')->get($this->_cookieName)) {  
  35.             Mage::app()->getResponse()->setRedirect(Mage::getUrl('sales/guest/form'));  
  36.             return false;  
  37.         } elseif (!empty($post) && isset($post['oar_order_id']) && isset($post['oar_type']))  {  
  38.             $type           = $post['oar_type'];  
  39.             $incrementId    = $post['oar_order_id'];  
  40.             $lastName       = $post['oar_billing_lastname'];  
  41.             $email          = $post['oar_email'];  
  42.             $zip            = $post['oar_zip'];  
  43.   
  44.             if (empty($incrementId) || empty($lastName) || empty($type) || (!in_array($typearray('email''zip')))  
  45.                 || ($type == 'email' && empty($email)) || ($type == 'zip' && empty($zip))) {  
  46.                 $errors = true;  
  47.             }  
  48.   
  49.             if (!$errors) {  
  50.                 $order->loadByIncrementId($incrementId);  
  51.             }  
  52.   
  53.             if ($order->getId()) {  
  54.                 $billingAddress = $order->getBillingAddress();  
  55.                 if ((strtolower($lastName) != strtolower($billingAddress->getLastname()))  
  56.                     || ($type == 'email'  
  57.                         && strtolower($email) != strtolower($billingAddress->getEmail()))  
  58.                     || ($type == 'zip'  
  59.                         && (strtolower($zip) != strtolower($billingAddress->getPostcode())))  
  60.                 ) {  
  61.                     $errors = true;  
  62.                 }  
  63.             } else {  
  64.                 $errors = true;  
  65.             }  
  66.   
  67.             if (!$errors) {  
  68.                 $toCookie = base64_encode($order->getProtectCode());  
  69.                 Mage::getSingleton('core/cookie')->set($this->_cookieName, $toCookie$this->_lifeTime, '/');  
  70.             }  
  71.         } elseif (Mage::getSingleton('core/cookie')->get($this->_cookieName)) {  
  72.             $fromCookie     = Mage::getSingleton('core/cookie')->get($this->_cookieName);  
  73.             $protectCode    = base64_decode($fromCookie);  
  74.   
  75.             if (!empty($protectCode)) {  
  76.                 $order->loadByAttribute('protect_code'$protectCode);  
  77.   
  78.                 Mage::getSingleton('core/cookie')->renew($this->_cookieName, $this->_lifeTime, '/');  
  79.             } else {  
  80.                 $errors = true;  
  81.             }  
  82.         }  
  83.   
  84.         if (!$errors && $order->getId()) {  
  85.             Mage::register('current_order'$order);  
  86.             return true;  

   关键是:


[php] view plain copy
  1. //如果没找到cookie的信息,就重定向到登录页面  
  2. f (empty($post) && !Mage::getSingleton('core/cookie')->get($this->_cookieName)) {  
  3.            Mage::app()->getResponse()->setRedirect(Mage::getUrl('sales/guest/form'));  
  4.            return false  

设置cookie的有效期是在:

[php] view plain copy
  1. $toCookie = base64_encode($order->getProtectCode());  
  2. Mage::getSingleton('core/cookie')->set($this->_cookieName, $toCookie$this->_lifeTime, '/');  

从上面的代码可看出,$this->_lifeTime 的值就是cookie的有效期,于是解决方法就很简单了,rewrite这个helper,把 $_lifeTime 设置为一个比较大的值就行了。


source: http://blog.csdn.net/newjueqi/article/details/7493007

你可能感兴趣的:(Magento)