Ce tutoriel explore la fonctionnalité par e-mail de Laravel, en tirant parti du composant Symfony Mailer. Nous couvrirons la configuration, la création de classes envoyables et l'envoi des e-mails, culminant dans un exemple pratique.
Configuration:
Laravel simplifie la gestion des e-mails via un emballage autour de Symfony Mailer. Le fichier de configuration principal est config/mail.php
. Ce fichier définit les expéditeurs (par exemple, SMTP, Sendmail, Mailgun, etc.) et leurs paramètres. Le mailer par défaut est spécifié par la variable d'environnement MAIL_MAILER
(dans .env
).
Pour SMTP, vous devrez configurer MAIL_HOST
, MAIL_PORT
, MAIL_ENCRYPTION
, MAIL_USERNAME
, et MAIL_PASSWORD
dans votre fichier .env
. Le pilote sendmail
nécessite de définir le chemin sendmail
correct dans config/mail.php
. L'adresse from
est également configurable. Les services tiers (Mailgun, CARM POST, SES) nécessitent une configuration supplémentaire dans config/services.php
.
Création d'une classe par mail:
Une classe envoyable gère la création et l'envoi des e-mails. Utilisez la commande artisan:
php artisan make:mail DemoEmail
Cela génère une classe DemoEmail
dans app/Mail/DemoEmail.php
. Une classe par mail typique comprend:
<?php namespace App\Mail; use Illuminate\Bus\Queueable; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Mail\Mailable; use Illuminate\Queue\SerializesModels; class DemoEmail extends Mailable { use Queueable, SerializesModels; public $demo; public function __construct($demo) { $this->demo = $demo; } public function build() { return $this->from('sender@example.com') ->view('mails.demo') ->text('mails.demo_plain') ->with(['testVarOne' => '1', 'testVarTwo' => '2']) ->attach(public_path('/images/demo.jpg'), ['as' => 'demo.jpg', 'mime' => 'image/jpeg']); } }
La méthode __construct
initialise les données, tandis que build
définit les spécificités des e-mails (expéditeur, vue, pièces jointes, etc.). Créer des fichiers de vue correspondants (resources/views/mails/demo.blade.php
et resources/views/mails/demo_plain.blade.php
).
Envoi des e-mails:
un contrôleur (par exemple, MailController
) utilise la façade Mail
pour envoyer des e-mails:
<?php namespace App\Http\Controllers; use App\Mail\DemoEmail; use Illuminate\Support\Facades\Mail; class MailController extends Controller { public function send() { $demoData = new \stdClass(); $demoData->demo_one = 'Demo Value 1'; $demoData->demo_two = 'Demo Value 2'; $demoData->sender = 'Sender Name'; $demoData->receiver = 'Receiver Name'; Mail::to("receiver@example.com")->send(new DemoEmail($demoData)); } }
La méthode Mail::to()->send()
envoie l'e-mail. Ajoutez un itinéraire dans routes/web.php
pour accéder au contrôleur.
pour tester sans envoyer des e-mails, définissez MAIL_DRIVER
à log
dans config/mail.php
pour enregistrer des e-mails à storage/logs/laravel.log
.
Conclusion:
Le système de courrier de Laravel, construit sur Symfony Mailer, propose une approche rationalisée à la gestion des e-mails. Ce didacticiel a démontré le processus de la configuration à l'envoi d'e-mails, en fournissant une base solide pour intégrer les fonctionnalités des e-mails dans vos applications Laravel. Explorez le marché de l'Envato pour d'autres ressources Laravel.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!