magento sales_order_place_after observer

jor*_*lli 14 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>
Run Code Online (Sandbox Code Playgroud)

在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>
Run Code Online (Sandbox Code Playgroud)

在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;
    }
}
?>  
Run Code Online (Sandbox Code Playgroud)

Debian Lenny上的Magento 1.4与Apache2如果出于任何原因应该重要.

Ala*_*orm 14

阅读我的文章,他们将帮助您从命名约定的角度理解正在发生的事情,并让您了解Magento的一些惯例/假设.

看看上面的示例,你有一些不太正确的事情.

首先,etc文件夹中的文件名称错误

magento/app/etc/modules/Feed.xml
Run Code Online (Sandbox Code Playgroud)

这个文件需要命名Packagename_Modulename,所以你可能想要

magento/app/etc/modules/Feed_Sales.xml
Run Code Online (Sandbox Code Playgroud)

查看系统 - >配置 - >高级以查看您的模块是否显示.如果是,您将正确命名此文件.如果没有这个,您创建的模块将不会加载到系统中,并且您的代码永远不会有机会运行.

接下来,您错误地指定了类.你说

sales/order_observer
Run Code Online (Sandbox Code Playgroud)

但URI(销售)的第一部分是不正确的.您将模型部分定义为

    <models>
        <feedsales> <!-- this is your model part -->
            <class>Feed_Sales_Model</class>
        </feedsales>
    </models>
Run Code Online (Sandbox Code Playgroud)

这意味着你想要的

feedsales/order_observer
Run Code Online (Sandbox Code Playgroud)

查看Commerce BugClass/URI选项卡,然后尝试输入一些URI(例如sales/order)以更好地了解这里发生了什么.

另一个快速提示,当您尝试设置处理程序时,请为每个页面加载时触发的事件执行此操作.然后,一旦调用了方法,就可以将其切换到所需的特定事件,而不必完成整个购买过程.

最后,我意识到你正在复制示例,考虑将你的模块放在一个名为其他东西的文件夹中Sales.我发现模仿Magento核心文件夹的名称只会增加一层额外的混乱,这不是你学习系统时所需要的.


jor*_*lli 0

碉堡了。我犯傻了。我使用命令行脚本对其进行了测试,就像我对很多事情所做的那样,但该特定文件只能由命令行解释器写入,而不能由 Apache 解释器写入。昨晚我应该早点离开办公室。

郑重声明,这就是触发下单操作的方式。我会把它留给后代。