Laravel 的 Events 及 Observers(五)
首先,我们为你展示如何通过模型观察者实现前面模式事件中的第一个例子。
在 app/Observers文件夹中创建 WelcomeUserObserver.php文件,并加入下面的代码:
<?php namespace App\Observers; class WelcomeUserObserver { public function created($user){ Mail::send('emails.welcome', ['user' => $user], function($message) use ($user) { $message->to($user->email, $user->first_name . ' ' . $user->last_name)->subject('Welcome to My Awesome App, '.$user->first_name.'!'); }); } }
然后在 EventServiceProvider的 boot()方法中注册该观察者:
/** * Register any other events for your application. * * @param \Illuminate\Contracts\Events\Dispatcher $events * @return void */ public function boot(DispatcherContract $events) { parent::boot($events); User::observe(new WelcomeUserObserver); }
这样就 OK 了!现在你的观察者已经与模型关联起来了。
下面我们假设另一种情况。图书管理员对代码提出了一些新的需求:
- 当添加一个新的作者的时候,每一个用户都收到一条通知
- 每次添加/删除作者的时候,都发送一封邮件
- 最后,每次删除一本书的时候,图书管理员都要知道数据库中有多少作者是没有与相关的图书的
好了,下面我们就开始吧。我们需要三个单独的类(请记住我们的 单一职责原则): CustomerNewAuthorObserver、 LibrarianAuthorObserver、 AuthorsWithoutBooksObservers。
注意:你可以按自己喜欢的方式命名这些类,我们这里只是选择比较容易与所选行为关联起来的名称。
下面我们分别来创建三个类:
<?php // file: app/Observers/CustomerNewAuthorObserver namespace App\Observers; class CustomerNewAuthorObserver { public function created($author) { } }<?php // file: app/Observers/LibrarianAuthorObserver namespace App\Observers; class LibrarianAuthorObserver { public function created($author) { } public function deleted($author) { } }<?php // file: app/Observers/AuthorsWithoutBooksObservers namespace App\Observers; class AuthorsWithoutBooksObservers { public function deleted($author) { } }
好了,现在应该添加一些逻辑了,首先为 CustomerNewAuthorObserver添加:
<?php // file: app/Observers/CustomerNewAuthorObserver namespace App\Observers; class CustomerNewAuthorObserver { public function created($author) { // getting all users... $users = \App\User::all(); foreach($users as $user) { Mail::send('emails.created_author_customer', ['author' => $author], function($message) use ($user) { $message->to($user->email, $user->first_name . ' ' . $user->last_name)->subject('New Author Added!'); }); } } }
注意:我知道这是一种非常简单粗暴的方法,这里只是为了实现上面的目的。实际情况中可以使用 邮件队列。
<?php // file: app/Observers/LibrarianAuthorObserver namespace App\Observers; class LibrarianAuthorObserver { public function created($author) { Mail::send('emails.created_author_librarian', ['author' => $author], function($message) use ($author) { $message->to('librarian@awesomelibrary.com', 'The Librarian')->subject('New Author: ' . $author->first_name . ' ' . $author->last_name); }); } public function deleted($author) { Mail::send('emails.deleted_author_librarian', ['author' => $author], function($message) use ($author) { $message->to('librarian@awesomelibrary.com', 'The Librarian')->subject('New Author: ' . $author->first_name . ' ' . $author->last_name); }); } }
最后:
<?php // file: app/Observers/AuthorsWithoutBooksObservers namespace App\Observers; class AuthorsWithoutBooksObservers { public function deleted($author) { $authorsWithoutBooks = \App\Author::has('books', '=', 0)->get(); if(count($authorsWithoutBooks) > 0){ Mail::send('emails.author_without_books_librarian', ['authorsWithoutBooks' => $authorsWithoutBooks], function($message) { $message->to('librarian@awesomelibrary.com', 'The Librarian')->subject('Authors without Books! A check is required!'); }); } } }
注意:就像前面提过的,我们假定你已经了解了 Laravel 发送邮件的基本知识,没有的话可以到官网学习下相关知识。
到这里并没有结束。你可以在大量的案例和场景中使用 Laravel 的模型事件和模型观察者。举个例子,假设你写博客,你希望每次发布一篇新文章或者更新一篇原有文章的时候,都更新一些站点地图,这时就可以用到观察者。再比如,当添加新书的时候,记录一些东西,也可以用到观察者。
该篇属于专题:《 Laravel 的 Events(事件) 及 Observers(观察者)》
- 下一篇:《 Laravel 的 Events 及 Observers(六) — 总结》
- 上一篇:《 Laravel 的 Events 及 Observers(四) — 模型观察者》

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Alipay PHP ...

In Artikel wird die in PHP 5.3 eingeführte LSB -Bindung (LSB) erörtert, die die Laufzeitauflösung der statischen Methode ermöglicht, um eine flexiblere Vererbung zu erfordern. Die praktischen Anwendungen und potenziellen Perfo von LSB

JWT ist ein offener Standard, der auf JSON basiert und zur sicheren Übertragung von Informationen zwischen Parteien verwendet wird, hauptsächlich für die Identitätsauthentifizierung und den Informationsaustausch. 1. JWT besteht aus drei Teilen: Header, Nutzlast und Signatur. 2. Das Arbeitsprinzip von JWT enthält drei Schritte: Generierung von JWT, Überprüfung von JWT und Parsingnayload. 3. Bei Verwendung von JWT zur Authentifizierung in PHP kann JWT generiert und überprüft werden, und die Funktionen und Berechtigungsinformationen der Benutzer können in die erweiterte Verwendung aufgenommen werden. 4. Häufige Fehler sind Signaturüberprüfungsfehler, Token -Ablauf und übergroße Nutzlast. Zu Debugging -Fähigkeiten gehört die Verwendung von Debugging -Tools und Protokollierung. 5. Leistungsoptimierung und Best Practices umfassen die Verwendung geeigneter Signaturalgorithmen, das Einstellen von Gültigkeitsperioden angemessen.

Die Hijacking der Sitzung kann in den folgenden Schritten erreicht werden: 1. Erhalten Sie die Sitzungs -ID, 2. Verwenden Sie die Sitzungs -ID, 3. Halten Sie die Sitzung aktiv. Zu den Methoden zur Verhinderung der Sitzung der Sitzung in PHP gehören: 1. Verwenden Sie die Funktion Session_regenerate_id (), um die Sitzungs -ID zu regenerieren. 2. Store -Sitzungsdaten über die Datenbank, 3. Stellen Sie sicher, dass alle Sitzungsdaten über HTTPS übertragen werden.

Die Anwendung des soliden Prinzips in der PHP -Entwicklung umfasst: 1. Prinzip der Einzelverantwortung (SRP): Jede Klasse ist nur für eine Funktion verantwortlich. 2. Open and Close Principle (OCP): Änderungen werden eher durch Erweiterung als durch Modifikation erreicht. 3.. Lischs Substitutionsprinzip (LSP): Unterklassen können Basisklassen ersetzen, ohne die Programmgenauigkeit zu beeinträchtigen. 4. Schnittstellen-Isolationsprinzip (ISP): Verwenden Sie feinkörnige Schnittstellen, um Abhängigkeiten und nicht verwendete Methoden zu vermeiden. 5. Abhängigkeitsinversionsprinzip (DIP): Hoch- und niedrige Module beruhen auf der Abstraktion und werden durch Abhängigkeitsinjektion implementiert.

So setzen Sie die Berechtigungen von Unixsocket automatisch nach dem Neustart des Systems. Jedes Mal, wenn das System neu startet, müssen wir den folgenden Befehl ausführen, um die Berechtigungen von Unixsocket: sudo ...

Wie debugge ich den CLI -Modus in PhpStorm? Bei der Entwicklung mit PHPSTORM müssen wir manchmal den PHP im CLI -Modus (COMS -Zeilenschnittstellen) debuggen ...

Statische Bindung (statisch: :) implementiert die späte statische Bindung (LSB) in PHP, sodass das Aufrufen von Klassen in statischen Kontexten anstatt Klassen zu definieren. 1) Der Analyseprozess wird zur Laufzeit durchgeführt.
