Magento 2事件观察员不工作

时间:2017-09-11 09:46:31

标签: php magento events module magento2

我正在尝试为我的Magento 2页面创建一个简单的事件观察器。

应用程序/代码/ NDAC /订单信息的/ etc / event.xml

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd">

   <event name="sales_order_place_after">
       <observer name="OrderInfo" instance="Ndac\Orderinfo\Observer\OrderInfo" />
   </event>

</config>

应用程序/代码/ NDAC /订单信息的/ etc / module.xml

<?xml version="1.0"?>
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Module/etc/module.xsd">
    <module name="Orderinfo" setup_version="1.0.0"></module>
</config>

应用程序/代码/ NDAC /订单信息/和registration.php

<?php \Magento\Framework\Component\ComponentRegistrar::register(\Magento\Framework\Component\ComponentRegistrar::MODULE,"Orderinfo", __DIR__);

应用程序/代码/ NDAC /订单信息/观察员/ OrderInfo.php

<?php
namespace Ndac\Orderinfo\Observer;

use Magento\Sales\Model\Order;
use Magento\Framework\Event\Observer;
use Magento\Framework\Event\ObserverInterface;

class OrderInfo implements ObserverInterface {
    // Tried it with constructor
    public __construct() {
        $file = fopen("/mnt/data/magento/test.txt", "w") or die ("die");
        fwrite($file, "test");
        fclose($file);
    }

    public function execute(Observer $observer)
    {
        $file = fopen("/mnt/data/magento/test.txt", "w") or die ("die")
        fwrite($file, "test");
        fclose($file);
    }
}
?>

我运行以下命令:bin/magento setup:upgrade并且模块显示在仪表板上,并且已启用,但在我下订单后,test.txt仍为空。

1 个答案:

答案 0 :(得分:4)

文件命名存在问题。

app/code/Ndac/Orderinfo/etc/event.xml

这必须是:

app/code/Ndac/Orderinfo/etc/events.xml

必须是events.xml。如果此事件无效,请尝试使用checkout_onepage_controller_success_action事件。

现在运行升级命令并清除缓存。