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 Bug的Class/URI选项卡,然后尝试输入一些URI(例如sales/order)以更好地了解这里发生了什么.
另一个快速提示,当您尝试设置处理程序时,请为每个页面加载时触发的事件执行此操作.然后,一旦调用了方法,就可以将其切换到所需的特定事件,而不必完成整个购买过程.
最后,我意识到你正在复制示例,考虑将你的模块放在一个名为其他东西的文件夹中Sales.我发现模仿Magento核心文件夹的名称只会增加一层额外的混乱,这不是你学习系统时所需要的.
碉堡了。我犯傻了。我使用命令行脚本对其进行了测试,就像我对很多事情所做的那样,但该特定文件只能由命令行解释器写入,而不能由 Apache 解释器写入。昨晚我应该早点离开办公室。
郑重声明,这就是触发下单操作的方式。我会把它留给后代。
| 归档时间: |
|
| 查看次数: |
41116 次 |
| 最近记录: |