我正在尝试挂钩“sales_order_save_after”事件,但是当事件被触发时我不断收到以下错误:
Mage registry key "_singleton/Modulename/Orderobserver" already exists
现在我已经检查过Orderobserver类是否正确命名,并且与xml中对类的调用匹配,但错误仍然存在。调用事件的xml如下所示:
<events>
<sales_order_save_after>
<observers>
<modulename>
<type>singleton</type>
<class>Modulename/Orderobserver</class>
<method>generateOrderFile</method>
</modulename>
</observers>
</sales_order_save_after>
</events>
该类名为Companyname_Modulename_Model_Modulename_Orderobserver
。
类文件的名称和位置如下:app/code/local/Companyname/Modulename/Model/Modulename/Orderobserver.php
有趣的是,发生错误时,服务器日志中也会记录以下错误:
client denied by server configuration:
/var/www/vhosts/path/to/subdomain/httpdocs/app/etc/local.xml
这可能是权限问题吗?
更新
我查看了Magento系统Log,并且还记录了以下错误:
Failed opening 'Mage/Retailpro/Model/Orderobserver.php' for inclusion (include_path='/var/www/path/to/subdomain/httpdocs/app/code/local:/var/www/path/to/subdomain/httpdocs/app/code/community:/var/www/path/to/subdomain/httpdocs/app/code/core:/var/www/path/to/subdomain/httpdocs/lib:.:') in /var/www/path/to/subdomain/httpdocs/lib/Varien/Autoload.php on line 93
答案 0 :(得分:9)
首先,虽然它可能不是必须的,但改变这个
<class>Modulename/Orderobserver</class>
到
<class>modulename/orderobserver</class>
关于类别名的约定是它们都是小写的。
其次,类别名modulename/orderobserver
转换为类名
Packagename_Modulename_Model_Orderobserver
所以你把你的类文件命名为错误。最后,由于Magento的自动加载器基于类名,这意味着您的文件需要位于
app/code/local/Packagename/Modulename/Model/Orderobserver.php
答案 1 :(得分:2)
如果&lt;
您将收到此错误事件&gt;在里面&lt;全球&gt;
将其移至&lt;前端&gt;&lt;事件&gt;或者&lt; adminhtml&gt;&lt;事件&gt;在&lt;之外全球&gt;要修复的标记。
答案 2 :(得分:0)
<global>
<models>
<newitems>
<class>Microtron_Newitems_Model</class>
<resourceModel>newitems_mysql4</resourceModel>
</newitems>
<newitems_mysql4>
<class>Microtron_Newitems_Model_Mysql4</class>
<entities>
<newitems>
<table>newitems</table>
</newitems>
</entities>
</newitems_mysql4>
</models>
<resources>
<newitems_setup>
<setup>
<module>Microtron_Newitems</module>
</setup>
<connection>
<use>core_setup</use>
</connection>
</newitems_setup>
<newitems_write>
<connection>
<use>core_write</use>
</connection>
</newitems_write>
<newitems_read>
<connection>
<use>core_read</use>
</connection>
</newitems_read>
</resources>
<events>
<catalog_product_save_after>
<observers>
<newitems>
<type>singleton</type>
<class>newitems/observer</class>
<method>catalog_product_save</method>
</newitems>
</observers>
</catalog_product_save_after>
</events>
</global>