magento无法加载观察类

KuK*_*uKu 0 events observers magento

当我尝试为checkout_type_onepage_save_order下面的事件编写观察者时

<events>
    <checkout_type_onepage_save_order>
        <observers>
            <Appeal_Consignor_Model_Observer>
                <type>singleton</type>
                <class>consignor/observer</class>
                <method>savedata</method>
            </Appeal_Consignor_Model_Observer>
        </observers>
    </checkout_type_onepage_save_order>
</events>
Run Code Online (Sandbox Code Playgroud)

以上代码我试过frontend以及global.

即使我也试过跟随.

<events>
    <checkout_type_onepage_save_order>
        <observers>
            <Appeal_Consignor_Model_Observer>
                <type>singleton</type>
                <class>Appeal_Consignor_Model_Observer</class>
                            <method>savedata</method>
            </Appeal_Consignor_Model_Observer>
        </observers>
    </checkout_type_onepage_save_order>
</events>
Run Code Online (Sandbox Code Playgroud)

完整的config.xml文件如下

<?xml version="1.0"?>
<config>
    <modules>
        <Appeal_Consignor>
            <version>1.0.1</version>
        </Appeal_Consignor>
    </modules>

    <global>
        <models>
            <consignor>
                <class>Appeal_Consignor_Model</class>
            </consignor>
        </models>
        <resources>
            <consignor_setup>
                <setup>
                    <module>Appeal_Consignor</module>
                </setup>
                <connection>
                    <use>core_setup</use>
                </connection>
            </consignor_setup>
            <consignor_write>
                <connection>
                    <use>core_write</use>
                </connection>
            </consignor_write>
            <consignor_read>
                <connection>
                    <use>core_read</use>
                </connection>
            </consignor_read>
        </resources>
        <helpers>
            <consignor>
                <class>Appeal_Consignor_Helper</class>
            </consignor>
        </helpers>
    </global>


    <frontend>
        <routers>
            <consignor>
                <use>standard</use>
                <args>
                    <module>Appeal_Consignor</module>
                    <frontName>consignor</frontName>
                </args>
            </consignor>
        </routers>


        <events>
            <checkout_type_onepage_save_order>
                <observers>
                    <Appeal_Consignor_Model_Observer>
                        <type>singleton</type>
                        <class>Appeal_Consignor_Model_Observer</class>
                        <method>savedata</method>
                    </Appeal_Consignor_Model_Observer>
                </observers>
            </checkout_type_onepage_save_order>

        </events>


    </frontend>
    <adminhtml>
        <layout>
            <updates>
                <consignor>
                    <file>consignor.xml</file>
                </consignor>
            </updates>
        </layout>


    </adminhtml>

</config>
Run Code Online (Sandbox Code Playgroud)

然而,以下错误即将来临.我清除缓存1000次,手动删除var cache文件夹文件.

2012-07-23T11:04:09+00:00 ERR (3): Warning: include(Appeal_Consignor_Model_Observer.php) [<a href='function.include'>function.include</a>]: failed to open stream: No such file or directory  in E:\xampp\htdocs\magento\includes\src\Varien_Autoload.php on line 93
2012-07-23T11:04:09+00:00 ERR (3): Warning: include() [<a href='function.include'>function.include</a>]: Failed opening 'Appeal_Consignor_Model_Observer.php' for inclusion (include_path='E:\xampp\htdocs\magento\includes\src;.;E:\xampp\php\PEAR')  in E:\xampp\htdocs\magento\includes\src\Varien_Autoload.php on line 93
Run Code Online (Sandbox Code Playgroud)

Dan*_*oof 6

通过包含警告判断,似乎您已启用编译器但无法找到(展平的)文件.

所以要么禁用编译器:

php shell/compiler.php disable
Run Code Online (Sandbox Code Playgroud)

或运行编译,以便它将为您生成文件:

php shell/compiler.php compile
Run Code Online (Sandbox Code Playgroud)

  • 这个.查看包含中的**文件**名称.包括(Appeal_Consignor_Model_Observer.php).每当你看到一个full_underscored_file_name,这意味着Magento正在寻找编译文件夹中的文件. (2认同)