我正在尝试编写一个观察员,在下订单时会导出订单数据。我之前没有写过任何模块。基于我对本文的实施:http://www.magentocommerce.com/wiki/5_-_modules_and_development/0_-_module_development_in_magento/customizing_magento_using_event-observer_method
到目前为止,我只是试图触发一些虚拟代码来写入文件。我没有在我的日志中显示任何内容,并且文件未被修改。 apache用户拥有该目录的权限。我在Magento设置中禁用了配置缓存。我对一些命名约定感到有些困惑;我只是试着效仿这个例子。谁知道我哪里出错了?
在magento / app / etc / modules / Feed.xml中:
<?xml version="1.0"?>
<config>
<modules>
<Feed_Sales>
<codePool>local</codePool>
<active>true</active>
</Feed_Sales>
</modules>
</config>
在magento / app / code / local / Feed / Sales / etc / config.xml中:
<?xml version="1.0"?>
<config>
<global>
<models>
<feedsales>
<class>Feed_Sales_Model</class>
</feedsales>
</models>
<events>
<sales_order_place_after>
<observers>
<feed_sales_order_observer>
<type>singleton</type>
<class>sales/order_observer</class><!-- I've also tried Feed_Sales_Model_Order_Observer here -->
<method>export_new_order</method>
</feed_sales_order_observer>
</observers>
</sales_order_place_after>
</events>
</global>
</config>
在magento / app / code / local / Feed / Sales / Model / Order / Observer.php中:
<?php
class Feed_Sales_Model_Order_Observer
{
public function __contruct()
{
}
/**
* Exports new orders to an xml file
* @param Varien_Event_Observer $observer
* @return Feed_Sales_Model_Order_Observer
*/
public function export_new_order($observer)
{
Mage::log("reached export_new_order");
try
{
$dumpFile = fopen('/home/jorelli/new_orders/testdump', 'w+');
fwrite($dumpFile, 'this is a test!');
}
catch (Exception $e)
{
Mage::log("order export failed.\n");
}
return $this;
}
}
?>
对于Debian Lenny,使用Apache2的Magento 1.4,如果它因任何原因而重要。
答案 0 :(得分:14)
阅读my articles,它们将帮助您从命名约定的角度理解正在发生的事情,并让您了解Magento的一些惯例/假设。
看看上面的示例,你有一些不太正确的事情。
首先,etc文件夹中的文件命名错误
magento/app/etc/modules/Feed.xml
此文件需要命名为Packagename_Modulename
,因此您可能需要
magento/app/etc/modules/Feed_Sales.xml
看看系统 - &gt;配置 - &gt;高级以查看您的模块是否显示。如果是,您将正确命名此文件。如果没有这个,您创建的模块将不会加载到系统中,并且您的代码永远无法运行。
接下来,您正在错误地指定类。你说
sales/order_observer
但URI(销售)的第一部分不正确。您将模型部分定义为
<models>
<feedsales> <!-- this is your model part -->
<class>Feed_Sales_Model</class>
</feedsales>
</models>
表示你想要
feedsales/order_observer
结帐Class/URI tab of Commerce Bug并尝试输入一些URI(例如sales/order
),以便更好地了解这里发生了什么。
另一个快速提示,当您尝试设置处理程序时,请为每个页面加载时触发的事件执行此操作。然后,一旦您调用了方法,就可以将其切换到您想要的特定事件,而不必完成整个购买过程。
最后,我意识到你正在复制示例,考虑将你的模块放在一个名为Sales
之外的文件夹中。我发现模仿Magento核心文件夹的名称只会增加一层额外的混乱,这不是你在学习系统时所需要的。
答案 1 :(得分:3)
问题似乎在于你的观察者声明。试一试:
<events>
<sales_order_place_after>
<observers>
<feed_sales_order_observer>
<type>singleton</type>
<class>feedsales/order_observer</class>
<method>export_new_order</method>
</feed_sales_order_observer>
</observers>
</sales_order_place_after>
</events>
答案 2 :(得分:0)
神圣的废话。我真蠢。我用命令行脚本测试了它,就像我做了很多事情一样,但是那个特定的文件只能由命令行解释器编写,而不是Apache解释器。我应该在昨晚早些时候离开办公室。
对于记录而言,这是您触发订单操作的方式。我会把它留给子孙后代。