Magento 2 事件观察器不工作

Magento 2 event observer not working

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

app/code/Ndac/Orderinfo/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>

app/code/Ndac/Orderinfo/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>

app/code/Ndac/Orderinfo/registration.php

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

app/code/Ndac/Orderinfo/Observer/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 在我下订单后仍然是空的。

文件命名有问题。

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

这必须是:

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

必须是events.xml。如果此事件不起作用,请尝试使用 checkout_onepage_controller_success_action 事件。

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