Maison >développement back-end >tutoriel php >Comment envoyer des e-mails dans Laravel

Comment envoyer des e-mails dans Laravel

Joseph Gordon-Levitt
Joseph Gordon-Levittoriginal
2025-03-07 01:15:24189parcourir

How to Send Emails in Laravel

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn