Apabila berurusan dengan beberapa acara operasi pengguna setiap hari, kadangkala kita perlu untuk merekodkannya, untuk rujukan kemudian atau statistik data besar.
Laravel sangat mudah dikendalikan dalam acara model: https://laravel-china.org/docs/laravel/5.5/eloquent#events
Model Laravel Di sana ialah dua cara peristiwa,
- Tetapkan
dispatchesEvents
kelas acara pemetaan atribut - Gunakan pemerhati untuk mendaftar acara, berikut adalah yang kedua
- Model baharu
php artisan make:model Log
<?php namespace App; use Illuminate\Database\Eloquent\Model; class Log extends Model { protected $fillable = ['user_name', 'user_id', 'url', 'event', 'method', 'table', 'description']; }
- Buat jadual migrasi:
php artisan make:migration create_logs_table
- jadual Struktur lebih kurang seperti ini, anda boleh mereka bentuknya mengikut keperluan
<?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('logs', 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'); } }
- Jalankan migrasi untuk menjana jadual
php artisan migrate
- Pembekal perkhidmatan Baharu mendaftar secara seragam semua pemerhati acara model (nama berikut boleh menjadi lebih jelas)
php artisan make:provider ObserverLogServiceProvider
- hingga
/config/app.php
providers
Pendaftaran tatasusunan (mungkin seperti yang ditunjukkan dalam gambar)
- Buat folder baharu di bawah
app
direktoriObservers
Simpan pemerhati model, cipta kelas asas baharuLogBaseServer
dan bina atribut asas dalam pembina (CLI adalah kerana tiada pelaksanaan pengguna semasa melaksanakan daripada baris arahan)
- Buat pemerhati baharu untuk mewarisi kelas asas
LogBaseServer
(modelPengguna, nama kaedah harus sepadan dengan acara dalam dokumen)
- Pergi ke penyedia perkhidmatan baharu
ObserverLogServiceProvider
dan jalankan
- Daftar acara untuk model yang diperlukan (Saya mempunyai agak sedikit, ia mungkin akan kelihatan seperti ini pada masa hadapan)
- Kemudian kami mencetuskan beberapa peristiwa (penambahan, pemadaman dan pengubahsuaian, data jadual akan tersedia)
- Sisipan perkaitan banyak-ke-banyak tidak akan mencetuskan model (seperti
attach
kaedah) - Pada masa ini, anda perlu mencipta kelas acara baharu untuk mensimulasikannya (di sini Mari kita bincangkan secara ringkas tentang memberikan kebenaran kepada peranan)
1 atribut EventServiceProvider
dalam listen
2. Suntikan dua parameter dalam acara PermissionRoleEvent
, satu ialah peranan, yang lain ialah tatasusunan yang dikembalikan oleh attach
atau detach
3. Pendengar acara PermissionRoleEventLog
juga mewarisi kelas asas LogBaseServer
, di sini ia dilalui mengikut id tatasusunan masuk, dan kemudian mencipta log
4. Kemudian gunakan acara
- Kendalikan acara log masuk dan log keluar lebih elegan
1. Ikat atribut EventServiceProvider
dalam subscribe
ke kelas yang diproses dengan baik
2 .Kaedah kelas mendengar acara
3 Kesan selepas itu: