Maison >cadre php >Laravel >Développement Laravel : Comment envoyer des SMS et des emails avec Laravel Notification ?

Développement Laravel : Comment envoyer des SMS et des emails avec Laravel Notification ?

王林
王林original
2023-06-13 10:33:061332parcourir

Développement Laravel : Comment envoyer des SMS et des e-mails à l'aide de Laravel Notification ?

Laravel est un framework d'application Web populaire basé sur PHP qui fournit un grand nombre de fonctionnalités et d'outils pour simplifier le développement d'applications Web. Laravel Notification est une fonctionnalité importante du framework Laravel, qui fournit un moyen simple et rapide d'envoyer des notifications, y compris des notifications par SMS et par e-mail.

Dans cet article, nous examinerons en profondeur comment utiliser Laravel Notification pour envoyer des notifications par SMS et par e-mail.

Étape 1 : Installez les dépendances nécessaires

Avant de commencer, nous devons installer deux dépendances obligatoires : le framework Laravel et le composant Laravel Notification.

Si vous possédez déjà une application Laravel, vous pouvez ignorer cette étape, sinon, ouvrez un terminal et entrez la commande suivante pour créer une nouvelle application Laravel :

composer create-project --prefer-dist laravel/laravel my-app

Une fois l'application créée, nous pouvons installer le composant de notification Laravel, il suffit exécutez la commande suivante dans le terminal :

composer require laravel-notification-channels/nexmo

Cette commande installera le pilote de notification nexmo, un pilote de notification qui peut être utilisé pour envoyer des SMS et des notifications vocales.

Étape 2 : Créer une classe de notification

Nous devons créer une classe de notification pour définir les notifications par SMS et par e-mail à envoyer. Nous pouvons créer une nouvelle classe de notification dans notre application Laravel en utilisant la commande suivante :

php artisan make:notification NewOrder

Cette commande créera une nouvelle classe de notification nommée NewOrder.php dans le répertoire app/Notifications. Cette classe définit le contenu de la notification et la manière dont elle est envoyée.

Voyons comment définir cette classe de notification.

Dans la méthode toNexmo, nous définissons le contenu et la méthode d'envoi des notifications. Si nous devons envoyer un message texte, nous pouvons ajouter ce qui suit à cette méthode :

return (new NexmoMessage)
    ->content('你收到了一条新订单。');

Si nous devons envoyer une notification par e-mail, nous pouvons ajouter ce qui suit à cette méthode :

return (new MailMessage)
    ->line('你收到了一条新订单。')
    ->action('查看订单', url('/orders'))
    ->line('谢谢你的使用。');

Nous pouvons ajouter d'autres méthodes dans la notification classe selon les besoins, par exemple : cc, bcc et réponse.

Troisième étape : Envoyer une notification

Nous avons défini la classe de notification, nous devons maintenant envoyer la notification dans l'application. Laravel propose plusieurs manières différentes d'envoyer des notifications, notamment des diffusions globales, des files d'attente et des événements.

Voyons comment envoyer des notifications dans le contrôleur.

Voici un simple extrait de code du contrôleur, nous pouvons envoyer une nouvelle notification de commande au client :

namespace AppHttpControllers;

use AppHttpControllersController;
use IlluminateHttpRequest;
use IlluminateSupportFacadesNotification;
use AppNotificationsNewOrder;

class OrderController extends Controller
{
    public function store(Request $request)
    {
        // 创建新订单的代码...

        $user = auth()->user();

        Notification::send($user, new NewOrder($order));
    }
}

Après l'exécution du code de création de chaque nouvelle commande, nous pouvons utiliser la classe de notification NewOrder pour envoyer une nouvelle commande au client notifier. Dans le code ci-dessus, nous utilisons la façade Notification de Laravel pour envoyer des notifications.

Étape 4 : Testez la notification

Nous avons écrit la classe de notification et le contrôleur et envoyé la notification à l'aide de la façade de notification de Laravel. Nous devons maintenant tester si la notification peut être envoyée correctement.

Testons d'abord l'envoi de notifications par e-mail. Ajoutez la méthode suivante dans la classe de notification pour définir l'adresse e-mail du destinataire du test d'e-mail :

public function toMail($notifiable)
{
    return (new MailMessage)
        ->to('test@example.com')
        ->line('你收到了一条新订单。')
        ->action('查看订单', url('/orders'))
        ->line('谢谢你的使用。');
}

Remarque : Il s'agit d'une adresse e-mail de test que vous devez définir en fonction de vos besoins.

Nous pouvons maintenant réécrire le code pour déclencher la notification, en utilisant un destinataire d'e-mail de test à la place du client réel :

Notification::route('mail', 'test@example.com')
    ->notify(new NewOrder($order));

Nous pouvons également tester l'envoi de notifications par SMS, ajouter la ligne suivante dans la classe de notification pour définir l'e-mail du Récepteur de test SMS Adresse e-mail :

public function toNexmo($notifiable)
{
    return (new NexmoMessage)
        ->to('+1234567890')
        ->content('你收到了一条新订单。');
}

Remarque : Il s'agit d'un numéro de téléphone de test, vous devez le configurer en fonction de vos besoins.

Maintenant, nous pouvons écrire du code pour déclencher des notifications, en utilisant un récepteur d'e-mail de test au lieu du client réel :

Notification::route('nexmo', '+1234567890')
    ->notify(new NewOrder($order));

Si vous recevez une notification par e-mail ou SMS, alors vous avez utilisé avec succès Laravel Notification pour envoyer des notifications.

Essayez d'utiliser Laravel Notification pour envoyer des notifications par SMS et par e-mail, j'espère que cela vous aidera à créer de meilleures applications Web.

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