magento sales_order_place_after observer

时间:2010-06-30 23:09:32

标签: php magento e-commerce

我正在尝试编写一个观察员,在下订单时会导出订单数据。我之前没有写过任何模块。基于我对本文的实施: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,如果它因任何原因而重要。

3 个答案:

答案 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解释器。我应该在昨晚早些时候离开办公室。

对于记录而言,这是您触发订单操作的方式。我会把它留给子孙后代。