Laravel 5.3 Mail senden Erweiterung: Benutzerdefinierte Datenbank -Mail -Protokoll
Laravel 5.3 bietet eine einfache Möglichkeit, E -Mails über eine Vielzahl beliebter Dienste zu konfigurieren und zu senden. Es umfasst jedoch nicht alle verfügbaren Dienste und erfordert möglicherweise eine Erweiterung vorhandener Mail -Treibersysteme.
Schlüsselpunkte:
IlluminateMailMailServiceProvider
erweitern, sodass die register
-Methode implementiert werden kann. Dies ermöglicht die Erstellung eines neuen Transportmanagers, der eine Swift -Mailer -Instanz an einen Container bindet. config/app.php
hinzu und registrieren Sie den Mail -Treiber in der Datei config/mail.php
in db
.
Laravel bietet viele praktische Funktionen, einschließlich der E -Mail -Lieferung. Sie können E -Mails problemlos über eine Vielzahl beliebter Dienste konfigurieren und senden, und es umfasst sogar Protokollassistent -Programme für die Entwicklung.
Mail::send('emails.welcome', ['user' => $user], function ($m) use ($user) { $m->to($user->email, $user->name)->subject('Welcome to the website'); });
verwendet dies emails.welcome
, um E -Mails an neu registrierte Benutzer auf der Website zu senden. Wenn Sie mailable in Laravel 5.3 verwendet werden, wird es einfacher (aber die alte Syntax ist noch gültig).
Folgendes ist ein Beispiel:
# 生成一个新的可邮件类 php artisan make:mail WelcomeMail
// app/Mail/WelcomeMail.php class WelcomeUser extends Mailable { use Queueable, SerializesModels; public $user; public function __construct(User $user) { $this->user = $user; } public function build() { return $this->view('emails.welcome'); } }
// routes/web.php Route::get('/', function () { $user = User::find(2); \Mail::to($user->email)->send(new WelcomeUser($user)); return "done"; });
Laravel bietet auch einen guten Ausgangspunkt für das Versenden von E -Mails mit Protokollentreibern während der Entwicklungsphase und SMTP, SparkPost, Mailgun usw. Während der Produktionsphase. Dies scheint in den meisten Fällen gut zu sein, aber es deckt nicht alle verfügbaren Dienste ab! In diesem Tutorial lernen wir, wie Sie ein vorhandenes Mail -Treibersystem erweitern, um unsere eigenen Treiber hinzuzufügen.
Um unser Beispiel einfach und klar zu machen, protokollieren wir das E -Mail -Protokoll in der Datenbanktabelle.
Die bevorzugte Methode, um dies zu erreichen, besteht darin, einen Dienstanbieter zu erstellen, der mit unserer Anwendung interagieren und unsere Dienste beim Start registrieren kann. Generieren wir zunächst einen neuen Dienstanbieter mit dem Artisan Command Line Assistant.
Mail::send('emails.welcome', ['user' => $user], function ($m) use ($user) { $m->to($user->email, $user->name)->subject('Welcome to the website'); });
Dies erstellt eine neue Klasse in unserem app/Providers
Ordner. Wenn Sie mit dem Laravel -Dienstanbieter vertraut sind, wissen Sie, dass wir die ServiceProvider
-Klasse erweitert und die Methoden boot
und register
definiert haben. Sie können mehr über den Anbieter in der Dokumentation lesen.
Anstatt die Klasse für den Elterndienstanbieter zu verwenden, können wir Abkürzungen einnehmen und die vorhandene IlluminateMailMailServiceProvider
erweitern. Dies bedeutet, dass die register
-Methode implementiert wurde.
# 生成一个新的可邮件类 php artisan make:mail WelcomeMail
registerSwiftMailer
gibt den entsprechenden Übertragungsfahrer gemäß dem Konfigurationswert mail.driver
zurück. Wir können hier eine Überprüfung durchführen, bevor wir die registerSwiftMailer
übergeordnete Methode aufrufen und unser eigenes Transfer Manager zurückgeben.
// app/Mail/WelcomeMail.php class WelcomeUser extends Mailable { use Queueable, SerializesModels; public $user; public function __construct(User $user) { $this->user = $user; } public function build() { return $this->view('emails.welcome'); } }
laravel analysiert die swift.mailer
-Schelle aus dem IOC, das die Swiftmailer -Instanz von Swift_Mailer zurückgeben sollte. Wir müssen unsere Swift Mailer -Instanz an den Container binden.
// routes/web.php Route::get('/', function () { $user = User::find(2); \Mail::to($user->email)->send(new WelcomeUser($user)); return "done"; });
Sie können das Übertragungsobjekt als den tatsächlichen Treiber behandeln. Wenn Sie den IlluminateMailTransport
-Namenspace überprüfen, finden Sie für jeden Fahrer verschiedene Transportklassen (z. B. LogTransport
, SparkPostTransport
usw.).
Swift_Mailer
Klasse erfordert eine Swift_Transport
-Stanz, die wir durch Erweiterung der IlluminateMailTransportTransport
-Klasse erfüllen können. Es sollte so aussehen.
php artisan make:provider DBMailProvider
Die einzige Möglichkeit, hier implementieren zu können, ist die send
-Methode. Es ist verantwortlich für die Mail -Senden -Logik. In diesem Fall sollten unsere E -Mails an der Datenbank protokolliert werden. Was unseren Konstruktor betrifft, können wir es vorerst leer lassen, da wir keine externen Abhängigkeiten benötigen.
$message->getTo()
Methode gibt immer ein assoziatives Array von Empfänger -E -Mail und Namen zurück. Wir verwenden die Funktion array_keys
, um die E -Mail -Liste zu erhalten, und fusionieren Sie sie dann, um die Zeichenfolge zu erhalten.
Der nächste Schritt besteht darin, die erforderlichen Migrationen für unsere Datenbanktabellen zu erstellen.
// vendor/Illuminate/Mail/MailServiceProvider.php public function register() { $this->registerSwiftMailer(); // ... }
// app/Providers/DBMailProvider.php function registerSwiftMailer() { if ($this->app['config']['mail.driver'] == 'db') { $this->registerDBSwiftMailer(); } else { parent::registerSwiftMailer(); } }
Unsere Migration enthält nur E -Mail -E -Mails und Empfänger -E -Mails, aber Sie können nach Bedarf weitere Details hinzufügen. Überprüfen Sie die Swift_Mime_Message
-Klassdefinition, um eine Liste der verfügbaren Felder anzuzeigen.
Jetzt müssen wir ein neues Modell erstellen, um mit unserer Tabelle zu interagieren und die erforderlichen Felder zum fillable
-Array hinzuzufügen.
Mail::send('emails.welcome', ['user' => $user], function ($m) use ($user) { $m->to($user->email, $user->name)->subject('Welcome to the website'); });
# 生成一个新的可邮件类 php artisan make:mail WelcomeMail
Okay, jetzt ist es an der Zeit, zu testen, was wir bisher erreicht haben. Wir fügen unseren Anbieter zuerst die Liste der Anbieter in der Datei config/app.php
hinzu.
// app/Mail/WelcomeMail.php class WelcomeUser extends Mailable { use Queueable, SerializesModels; public $user; public function __construct(User $user) { $this->user = $user; } public function build() { return $this->view('emails.welcome'); } }
Dann registrieren wir den Mail -Treiber in config/mail.php
in der Datei db
.
// routes/web.php Route::get('/', function () { $user = User::find(2); \Mail::to($user->email)->send(new WelcomeUser($user)); return "done"; });
Der einzige verbleibende Teil ist das Senden einer Test -E -Mail und überprüft, ob sie in die Datenbank angemeldet ist. Ich werde eine E -Mail senden, wenn ich auf die Homepage -URL zugriff. Das Folgende ist der Code.
php artisan make:provider DBMailProvider
Nach dem Zugriff auf die Homepage -Route können wir den Befehl php artisan tinker
ausführen, um den Tabellensatz emails
zu überprüfen.
In diesem Artikel sehen wir, wie das Mail -Treibersystem erweitert wird, um E -Mails zum Debuggen abzufangen. Eine Sache, die ich in Laravel schätze, ist die beispiellose Skalierbarkeit: Sie können alles ändern oder erweitern, von Routern und IOCs bis Mail und fast alles andere.
Wenn Sie Fragen oder Kommentare haben, posten Sie sie bitte unten und ich werde mein Bestes geben, um zu beantworten!
Erweiterung des Postfahrers in Laravel 5.3 Beinhaltet die Erstellung eines neuen Dienstanbieters. Dieser Dienstanbieter erweitert den vorhandenen Mail -Treiber und ermöglicht Ihnen, zusätzliche Funktionen hinzuzufügen. Sie können den Befehl php artisan make:provider
verwenden, um einen neuen Dienstanbieter zu erstellen. Nach dem Erstellen des Anbieters können Sie ihn in der Datei config/app.php
registrieren. Im Anbieter können Sie mit der Methode extend
dem Mail -Treiber benutzerdefinierte Funktionen hinzufügen.
E -Mail -Protokollierung in Laravel ist eine Funktion, mit der Sie alle von Ihrer Bewerbung gesendeten ausgehenden E -Mails verfolgen können. Dies ist sehr nützlich für das Debuggen, da Sie genau sehen können, welche E -Mails, wann und an wen gesendet werden. Es ist auch sehr nützlich für die Prüfung, da es eine Aufzeichnung aller von der Bewerbung gesendeten E -Mail -Mitteilungen enthält.
Um Laravel so zu konfigurieren, dass alle ausgehenden E -Mails aufgezeichnet werden, müssen Sie die Datei config/mail.php
ändern. In dieser Datei können Sie die Option log
auf true
festlegen. Dies weist Laravel an, alle ausgehenden E -Mails zu protokollieren. Die Protokolle werden im Verzeichnis storage/logs
gespeichert.
Die Mail -Protokolle in Laravel werden im Verzeichnis storage/logs
gespeichert. Sie können diese Protokolle anzeigen, indem Sie zu diesem Verzeichnis navigieren und die Protokolldatei öffnen. Die Protokolldateien werden nach Daten benannt, sodass Sie problemlos Protokolle für bestimmte Daten finden können.
Ja, Sie können das Format von Mail -Protokollen in Laravel anpassen. Dies kann durch Erweiterung des Mailtreibers und Überschreiben der log
-Methode erfolgen. In dieser Methode können Sie das Format der Protokollnachricht angeben.
(Der Rest der FAQ bezieht sich auf die E -Mail, die sich selbst sendet, und hat in diesem Beispiel nichts mit der E -Mail -Protokoll -Erweiterung zu tun.
Bitte beachten Sie, dass die Bildpfade und /uploads/20250210/173915090467a9563807841.webp
und /uploads/20250210/173915090467a9563839bfc.webp
durch tatsächliche zugängliche Bildlinks ersetzt werden müssen. /uploads/20250210/173915090667a9563a27b41.jpg
Das obige ist der detaillierte Inhalt vonE -Mail -Protokollierung in Laravel 5.3: Erweiterung des Mailtreibers. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!