当有人点击下订单但我没有开火时,我正在尝试运行某个活动。我知道它有效,因为我可以将事件更改为产品更新,当我更新它在日志文件中写入的产品时。我正在使用粉碎杂志教程,只是改变了事件。
我已尝试过这两个事件:
checkout_submit_all_after
checkout_onepage_controller_success_action
我做错了什么?
的Config.xml
<?xml version="1.0" encoding="UTF-8"?>
<config>
<modules>
<SmashingMagazine_LogProductUpdate>
<version>0.0.1</version>
</SmashingMagazine_LogProductUpdate>
</modules>
<!-- Configure our module's behavior in the global scope -->
<global>
<!-- Defining models -->
<models>
<!--
Unique identifier in the model's node.
By convention, we put the module's name in lowercase.
-->
<smashingmagazine_logproductupdate>
<!--
The path to our models directory, with directory
separators replaced by underscores
-->
<class>SmashingMagazine_LogProductUpdate_Model</class>
</smashingmagazine_logproductupdate>
</models>
<events>
<checkout_submit_all_after>
<observers>
<smashingmagazine_logproductupdate>
<class>smashingmagazine_logproductupdate/observer</class>
<method>logUpdate</method>
<type>singleton</type>
</smashingmagazine_logproductupdate >
</observers>
</catalog_product_save_after>
</events>
</global>
</config>
Observer.php
<?php
/**
* Our class name should follow the directory structure of
* our Observer.php model, starting from the namespace,
* replacing directory separators with underscores.
* i.e. app/code/local/SmashingMagazine/
* LogProductUpdate/Model/Observer.php
*/
class SmashingMagazine_LogProductUpdate_Model_Observer
{
/**
* Magento passes a Varien_Event_Observer object as
* the first parameter of dispatched events.
*/
public function logUpdate(Varien_Event_Observer $observer)
{
// Write a new line to var/log/product-updates.log
$name = 'asdf';
$sku = 'weee';
Mage::log(
"{$name} ({$sku}) updated",
null,
'product-updates.log'
);
}
}
答案 0 :(得分:5)
尝试使用以下示例直接放置observer类和语法,以及在</smashingmagazine_logproductupdate >
这样的唯一标记中有空格,这应该是</smashingmagazine_logproductupdate>
<events>
<checkout_submit_all_after>
<observers>
<smashingmagazine_logproductupdate>
<class>SmashingMagazine_LogProductUpdate_Model_Observer</class>
<method>logUpdate</method>
</smashingmagazine_logproductupdate>
</observers>
</checkout_submit_all_after>
</events>
希望这一定会帮助您解决问题。
答案 1 :(得分:0)
在Magento中创建config xml时需要注意一些事项。
始终使用<Namesapce_Modulename>
而不是<NameSpace_ModuleName>
,因为当您使用namesapce/modulename
创建对象时它将无效,因为Magento会尝试查找类似Namespace_Modulename_Model_Class
而不是NameSpace_ModuleName_Model_Class
的类
在您的情况下,要么正确更改名称空间和模块名称,要么使用以下config.xml
<events>
<checkout_submit_all_after>
<observers>
<SmashingMagazine_LogProductUpdate_Model_Observer>
<class>SmashingMagazine_LogProductUpdate_Model_Observer</class>
<method>logUpdate</method>
<type>singleton</type>
</SmashingMagazine_LogProductUpdate_Model_Observer>
</observers>
</catalog_product_save_after>
</events>