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

Comment envoyer des e-mails dans Laravel

Joseph Gordon-Levitt
Libérer: 2025-03-07 01:15:24
original
186 Les gens l'ont consulté

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
Copier après la connexion

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']);
    }
}
Copier après la connexion

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));
    }
}
Copier après la connexion

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 de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal