触发事件时“Mage注册表键已存在”

时间:2011-07-25 12:23:40

标签: events magento registry

我正在尝试挂钩“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

3 个答案:

答案 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>