Heim  >  Artikel  >  PHP-Framework  >  Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

藏色散人
藏色散人nach vorne
2021-07-23 15:03:052710Durchsuche

Wenn wir uns täglich mit einigen Benutzerbetriebsereignissen befassen, müssen wir sie manchmal für spätere Referenzzwecke oder für Big-Data-Statistiken aufzeichnen.


Laravel ist sehr praktisch für die Handhabung von Modellereignissen: https://laravel-china.org/docs/laravel/5.5/eloquent#events


Laravels Modellereignisse haben zwei Möglichkeiten:

  • settingsdispatchesEventsAttribute-Mapping-Ereignisklasse
  • dispatchesEvents属性映射事件类
  • 使用观察器来注册事件,这里介绍第二种
  • 新建模型

php artisan make:model Log

<?php namespace App;

use Illuminate\Database\Eloquent\Model;

class Log extends Model
{
    protected $fillable = [&#39;user_name&#39;, &#39;user_id&#39;, &#39;url&#39;, &#39;event&#39;, &#39;method&#39;, &#39;table&#39;, &#39;description&#39;];
}
  • 创建迁移表:

php artisan make:migration create_logs_table

  • 表的结构大概是这样,可按需设计
<?php use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;

class CreateLogsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create(&#39;logs&#39;, function (Blueprint $table) {
            $table->engine = 'InnoDB';
            $table->increments('id');
            $table->string('user_id')->comment('操作人的ID');
            $table->string('user_name')->comment('操作人的名字,方便直接查阅');
            $table->string('url')->comment('当前操作的URL');
            $table->string('method')->comment('当前操作的请求方法');
            $table->string('event')->comment('当前操作的事件,create,update,delete');
            $table->string('table')->comment('操作的表');
            $table->string('description')->default('');
            $table->timestamps();
        });

        DB::statement("ALTER TABLE `logs` comment '操作日志表'");
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('logs');
    }
}
  • 运行迁移生成表

php artisan migrate

  • 新建一个服务提供者统一注册所有的模型事件观察器(后面的名字可以自己起得形象一点)

php artisan make:provider ObserverLogServiceProvider

  • /config/app.php中的providers数组注册(大概如图中)

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

  • app目录下新建文件夹Observers存放模型观察器,并新建基类LogBaseServer并在构造函数构建基本属性(CLI是因为在命令行执行时不存在用户执行)

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

  • 新建一个观察器继承基类LogBaseServerUser模型,方法的名字要对应文档中的事件)

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

  • 到新建的服务提供者ObserverLogServiceProvider中运行

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

  • 为需要的模型注册事件(我这挺多的,之后大概长这样)

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

  • 然后我们触发一些事件(增删改,表的数据就有了)

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen


  • 多对多的关联插入不会出触发模型(比如attach方法)
  • 这时候就需要自己新建事件类来模拟(这里拿分配权限给角色粗略说一下)

1.在EventServiceProvider中的listen属性绑定好事件

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

2.事件PermissionRoleEvent中的注入两个参数,一个是角色,另一个是attach或者detachVerwenden Sie Beobachter, um Ereignisse zu registrieren

Neues Modell

php artisan make: model Log code><span class="img-wrap">rrreee<img class="lazy" referrerpolicy="no-referrer" src="/img/remote/1460000013815118?w=1345&h=665" alt="" title=""><img src="https://img.php.cn/upload/image/492/109/627/1627023592973459.png" title="1627023592973459.png" alt="Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen">Migrationstabelle erstellen:</span><code>php artisan make:migration create_logs_table

🎜🎜Die Struktur der Tabelle ist ungefähr so ​​und kann so gestaltet werden erforderlich rrreee🎜🎜Führen Sie die Migrationsgenerierungstabelle aus 🎜php artisan migrate🎜🎜🎜Erstellen Sie einen neuen Dienstanbieter, um alle Modellereignisse einheitlich zu registrieren Observers (Letzterer Name kann für Sie selbst anschaulicher sein)🎜php artisan make:provider ObserverLogServiceProvider🎜🎜🎜to /config/app.php providers Array-Registrierung (wahrscheinlich wie im Bild gezeigt)🎜🎜Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜🎜🎜🎜Erstellen Sie einen neuen Ordner Observers im Verzeichnis app, um den Modellbeobachter zu speichern, und erstellen Sie einen Neue Basisklasse LogBaseServer und grundlegende Attribute im Konstruktor erstellen (CLI liegt daran, dass bei der Ausführung über die Befehlszeile keine Benutzerausführung erfolgt)🎜🎜Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜🎜🎜🎜Erstellen Sie einen neuen Beobachter die Basisklasse LogBaseServer ( 🎜Benutzer🎜 Modell, Methodenname Entspricht den Ereignissen im Dokument)🎜🎜 Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜🎜🎜🎜Gehen Sie zum neu erstellten Dienstanbieter ObserverLogServiceProvider und führen Sie ihn aus🎜🎜Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜🎜🎜🎜Ereignisse für die erforderlichen Modelle registrieren (ich habe eine Menge von ihnen wird es wahrscheinlich in Zukunft so aussehen)🎜🎜Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜🎜🎜🎜 Dann lösen wir einige Ereignisse aus (Hinzufügungen, Löschungen, Änderungen, Tabellendaten. Da haben Sie es)🎜🎜Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜 🎜🎜🎜🎜Many-to-many-Assoziationseinfügung erzeugt kein Triggermodell (z. B. ). anhängen Methode)🎜Zu diesem Zeitpunkt müssen Sie eine neue Ereignisklasse erstellen, um sie zu simulieren (hier weisen wir Rollen grob Berechtigungen zu. Sprechen Sie darüber)🎜1 Binden Sie das Ereignis an das listen-Attribut in EventServiceProvider🎜🎜🎜Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen🎜🎜🎜2. Fügen Sie zwei Parameter in das Ereignis PermissionRoleEvent ein, einer ist eine Rolle, der andere ist das von attach oder abtrennen🎜🎜🎜🎜🎜🎜🎜

3. Der Ereignis-Listener PermissionRoleEventLog erbt auch die Basisklasse LogBaseServer, durchläuft hier entsprechend der übergebenen Array-ID und erstellt dann das Protokoll PermissionRoleEventLog也继承基类LogBaseServer,这里就是根据传入的数组id遍历,然后创建日志

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

4.之后应用事件

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen


  • 更优雅的处理登录注销事件

1.在EventServiceProvider中的subscribe

Detaillierte Erklärung der beiden Arten von Laravel-ModellereignissenDetaillierte Erklärung der beiden Arten von Laravel-Modellereignissen4. Wenden Sie das Ereignis anschließend an

Detaillierte Erklärung der beiden Arten von Laravel-Modellereignissen


  • Anmelde- und Abmeldeereignisse eleganter handhaben li>
1. Binden Sie das Attribut subscribe in EventServiceProvider an die verarbeitete KlasseDetaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

2. Methoden von Event-Listening-KlassenDetaillierte Erklärung der beiden Arten von Laravel-Modellereignissen

3.

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung der beiden Arten von Laravel-Modellereignissen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen