Magento ล้มเหลวเมื่อพยายามบันทึกผลิตภัณฑ์ภายในผู้สังเกตการณ์เหตุการณ์ที่ส่วนหน้า?


15

ฉันมีฟังก์ชั่นที่เชื่อมโยงกับผู้สังเกตการณ์เหตุการณ์

หนึ่งในความต้องการคือเมื่อลูปผ่านข้อมูลรายการสั่งซื้อหากแอตทริบิวต์ผลิตภัณฑ์บางอย่างว่างเปล่าจะมีการร้องขอให้รับข้อมูลที่เฉพาะเจาะจงผ่านรูปแบบที่แยกต่างหาก (ทำงานได้ดี)

รหัสปัญหาโดยทั่วไปจะลดลงถึงสิ่งนี้

foreach ($order->getAllItems() as $key => $item) {
    /** @var Tantor_Catalog_Model_Product $productData */
    $productData = $item->getProduct();
    $_item = Mage::getModel('catalog/product')->load($productData->getId());
    $_item->setNetsuiteItemIid('foo');
    $_item->save();
}

อย่างไรก็ตามวีโอไอพีกำลังขว้างข้อยกเว้น

2014-03-05T21:14:14+00:00 ERR (3):
exception 'Exception' with message 'Warning: Invalid argument supplied for foreach()  in /var/www/html/app/code/core/Mage/Eav/Model/Entity/Abstract.php on line 1180' in /var/www/html/app/code/core/Mage/Core/functions.php:245
Stack trace:
#0 /var/www/html/app/code/core/Mage/Eav/Model/Entity/Abstract.php(1180): mageCoreErrorHandler(2, 'Invalid argumen...', '/var/www/html/a...', 1180, Array)
#1 /var/www/html/app/code/core/Mage/Eav/Model/Entity/Abstract.php(1123): Mage_Eav_Model_Entity_Abstract->_collectSaveData(Object(Tantor_Catalog_Model_Product))
#2 /var/www/html/app/code/core/Mage/Core/Model/Abstract.php(318): Mage_Eav_Model_Entity_Abstract->save(Object(Tantor_Catalog_Model_Product))
#3 /var/www/html/app/code/local/Tantor/Netsuite/Model/Observer.php(218): Mage_Core_Model_Abstract->save()
#4 /var/www/html/app/code/core/Mage/Core/Model/App.php(1338): Tantor_Netsuite_Model_Observer->saveOrder(Object(Varien_Event_Observer))
#5 /var/www/html/app/code/core/Mage/Core/Model/App.php(1317): Mage_Core_Model_App->_callObserverMethod(Object(Tantor_Netsuite_Model_Observer), 'saveOrder', Object(Varien_Event_Observer))
#6 /var/www/html/app/Mage.php(447): Mage_Core_Model_App->dispatchEvent('sales_order_pla...', Array)
#7 /var/www/html/app/code/core/Mage/Sales/Model/Order.php(1096): Mage::dispatchEvent('sales_order_pla...', Array)
#8 [internal function]: Mage_Sales_Model_Order->place()
#9 /var/www/html/app/code/core/Mage/Core/Model/Resource/Transaction.php(105): call_user_func(Array)
#10 /var/www/html/app/code/core/Mage/Core/Model/Resource/Transaction.php(159): Mage_Core_Model_Resource_Transaction->_runCallbacks()
#11 /var/www/html/app/code/core/Mage/Sales/Model/Service/Quote.php(189): Mage_Core_Model_Resource_Transaction->save()
#12 /var/www/html/app/code/core/Mage/Sales/Model/Service/Quote.php(249): Mage_Sales_Model_Service_Quote->submitOrder()
#13 /var/www/html/app/code/core/Mage/Checkout/Model/Type/Onepage.php(774): Mage_Sales_Model_Service_Quote->submitAll()
#14 /var/www/html/app/code/core/Mage/Checkout/controllers/OnepageController.php(511): Mage_Checkout_Model_Type_Onepage->saveOrder()
#15 /var/www/html/app/code/core/Mage/Core/Controller/Varien/Action.php(419): Mage_Checkout_OnepageController->saveOrderAction()
#16 /var/www/html/app/code/core/Mage/Core/Controller/Varien/Router/Standard.php(250): Mage_Core_Controller_Varien_Action->dispatch('saveOrder')
#17 /var/www/html/app/code/core/Mage/Core/Controller/Varien/Front.php(176): Mage_Core_Controller_Varien_Router_Standard->match(Object(Mage_Core_Controller_Request_Http))
#18 /var/www/html/app/code/core/Mage/Core/Model/App.php(354): Mage_Core_Controller_Varien_Front->dispatch()
#19 /var/www/html/app/Mage.php(683): Mage_Core_Model_App->run(Array)
#20 /var/www/html/index.php(86): Mage::run('', 'store')
#21 {main}

ทำไมฉันถึงสามารถใช้รหัสที่เหมือนกันในสคริปต์ของบุคคลภายนอกนอกผู้สังเกตการณ์วีโอไอพีได้ดี แต่เมื่อฉันพยายามเรียกใช้ภายในผู้สังเกตการณ์นั้นมันล้มเหลวด้วยข้อความแสดงข้อผิดพลาดแบบสุ่ม?


foreachข้อผิดพลาดนี้เป็นเรื่องปกติของที่ไม่ใช่อาร์เรย์ถูกแยกออกเป็น การติดตามสแต็กแสดงเหตุการณ์ที่ถูกจัดส่งและผู้สังเกตการณ์ผิดพลาด คุณแน่ใจ$order->getAllItems()จะ retuning array()? Zend_Debug::dump($order->getAllItems());ใช้: อย่างไรก็ตามอาจเป็นผู้สังเกตการณ์อีกคนที่มีรหัสไม่ดีบ้าง
เถ้าถ่าน

ปัญหาอยู่ที่รหัสหลักของวีโอไอพีไม่ใช่กับตัวอย่างข้อมูลของฉันที่ด้านบน
Zxurian

คำตอบ:


33

ปัญหาคือว่าคุณไม่ได้รับอนุญาตให้บันทึกผลิตภัณฑ์จากส่วนหน้า

สิ่งนี้ทำผ่านข้อเท็จจริงที่ว่าเมื่อคุณโหลดผลิตภัณฑ์ในส่วนหน้าorigDataคุณสมบัติจะไม่ถูกเติม:

public function setOrigData($key=null, $data=null)
{
    if (Mage::app()->getStore()->isAdmin()) {
        return parent::setOrigData($key, $data);
    }

    return $this;
}

ดังนั้นเมื่อคุณพยายามบันทึกผลิตภัณฑ์ข้อผิดพลาดที่คุณอธิบายจะเพิ่มขึ้น

คุณสามารถแก้ปัญหานี้ได้ทั้งเมื่อคุณเปลี่ยนที่เก็บปัจจุบันเป็นผู้ดูแลระบบเช่นด้วยรหัสจาก @magboy:

Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);

ใช้ดีกว่า Mage_Core_Model_App_Emulation

และโซลูชันที่ฉันต้องการคือการขยายMage_Catalog_Model_Productและแทนที่setOrigDataวิธี

public function setOrigData($key = null, $data = null)
{
    if (is_null($key)) {
        $this->_origData = $this->_data;
    } else {
        $this->_origData[$key] = $data;
    }
    return $this;
}

ฉันไม่ได้พูดถึงการเขียนที่นี่! ใช้แบบจำลองของคุณในที่เดียวเพื่อเปิดใช้งานการบันทึก จากนั้นคุณมีคุณสมบัติความปลอดภัยยังใช้งานได้ทุกที่อื่น


7

ลองเพิ่มรหัสบรรทัดนี้:

Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);

ฉันไม่แน่ใจว่าทำไมคุณต้องทำสิ่งนี้ใน Magento เวอร์ชันปัจจุบัน บางทีคนอื่นสามารถอธิบายได้?


หลังจากที่ฉันตั้งค่า currentstore เป็น Admin และบันทึกผลิตภัณฑ์ฉันต้องตั้งค่ากลับเป็นค่าดั้งเดิมหรือไม่
Giuseppe

1
@Giuseppe มันขึ้นอยู่กับสิ่งที่คุณทำในภายหลังกับคำขอ; มันสะอาดและจะนำไปสู่ปัญหาน้อยลงถ้าคุณทำมัน
simonthesorcerer
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.