CakePHP-Middleware: Integrieren Sie E-Mail- und SMS-Dienste, um Nachrichtenbenachrichtigungen zu implementieren

王林
Freigeben: 2023-07-28 11:14:01
Original
1154 Leute haben es durchsucht

CakePHP-Middleware: Integrieren Sie E-Mail- und SMS-Dienste, um Nachrichtenbenachrichtigungen zu implementieren

Einführung:
In modernen Webanwendungen sind Nachrichtenbenachrichtigungen eine sehr wichtige Funktion. Benutzer müssen wichtige Informationen vom System erhalten, z. B. erfolgreiche Registrierung, Zurücksetzen des Passworts, Aktualisierungen des Bestellstatus usw. Um diese Funktionalität zu erreichen, ist die Integration von E-Mail- und SMS-Diensten zu einem gängigen Ansatz geworden. In diesem Artikel werde ich die Verwendung der CakePHP-Middleware zur Implementierung der Nachrichtenbenachrichtigungsfunktion vorstellen und einige spezifische Codebeispiele bereitstellen.

  1. Umgebungsvorbereitung:
    Zuerst müssen wir sicherstellen, dass das CakePHP-Framework korrekt installiert und konfiguriert wurde. Darüber hinaus benötigen wir gültige API-Schlüssel für E-Mail- und SMS-Dienstanbieter. In diesem Artikel verwende ich Mailgun als E-Mail-Dienstanbieter und Twilio als SMS-Dienstanbieter.
  2. Mail-Dienst konfigurieren:
    In CakePHP können wir den von Mailgun bereitgestellten E-Mail-Dienst nutzen, indem wir SMTP-Einstellungen in der Datei config/app.php konfigurieren.
// app.php

'EmailTransport' => [
    'default' => [
        'className' => 'CakeMailerTransportMailgunTransport',
        'apiKey' => 'YOUR_MAILGUN_API_KEY',
        'domain' => 'YOUR_MAILGUN_DOMAIN',
        'url' => 'YOUR_MAILGUN_API_URL',
    ],
],
Nach dem Login kopieren

Wir müssen YOUR_MAILGUN_API_KEY, YOUR_MAILGUN_DOMAIN und YOUR_MAILGUN_API_URL durch die tatsächlichen Werte ersetzen. YOUR_MAILGUN_API_KEYYOUR_MAILGUN_DOMAINYOUR_MAILGUN_API_URL替换为实际的值。

  1. 配置短信服务:
    对于短信服务,我们将使用Twilio提供的API。在CakePHP中,我们可以通过在config/app.php文件中配置Twilio设置来使用他们的服务。
// app.php

'Twilio' => [
    'sid' => 'YOUR_TWILIO_SID',
    'token' => 'YOUR_TWILIO_TOKEN',
    'sender' => 'YOUR_TWILIO_PHONE_NUMBER',
],
Nach dem Login kopieren

同样,我们需要将YOUR_TWILIO_SIDYOUR_TWILIO_TOKENYOUR_TWILIO_PHONE_NUMBER

    SMS-Dienst konfigurieren:
      Für den SMS-Dienst verwenden wir die von Twilio bereitgestellte API. In CakePHP können wir ihre Dienste nutzen, indem wir die Twilio-Einstellungen in der Datei config/app.php konfigurieren.

    1. // src/Middleware/NotificationMiddleware.php
      
      namespace AppMiddleware;
      
      use CakeMailerMailerAwareTrait;
      use CakeMailerEmail;
      use TwilioRestClient;
      
      class NotificationMiddleware
      {
          use MailerAwareTrait;
      
          public function __invoke($request, $response, $next)
          {
              // 执行下一个中间件之前的代码
              // ...
      
              // 发送电子邮件
              $this->getMailer('Default')->send('notification', [$data]);
      
              // 发送短信
              $twilio = new Client(getenv('TWILIO_SID'), getenv('TWILIO_TOKEN'));
              $twilio->messages->create(
                  $phoneNumber,
                  [
                      'from' => getenv('TWILIO_SENDER'),
                      'body' => $message,
                  ]
              );
      
              // 执行下一个中间件之后的代码
              // ...
      
              return $next($request, $response);
          }
      }
      Nach dem Login kopieren
    2. Ebenso müssen wir YOUR_TWILIO_SID, YOUR_TWILIO_TOKEN und YOUR_TWILIO_PHONE_NUMBER durch die tatsächlichen Werte ersetzen.

    Middleware erstellen:
      Jetzt können wir mit dem Schreiben der CakePHP-Middleware beginnen, um die Nachrichtenbenachrichtigungsfunktion zu implementieren. Zuerst erstellen wir eine Datei mit dem Namen NotificationMiddleware.php und legen sie im Verzeichnis src/Middleware ab.

    1. // config/bootstrap.php
      
      use AppMiddlewareNotificationMiddleware;
      use CakeHttpMiddlewareQueue;
      
      $middlewareQueue = new MiddlewareQueue();
      $middlewareQueue->add(new NotificationMiddleware());
      
      // 替换原有的middlewareQueue
      // ...
      
      // 设置新的middlewareQueue
      $application->setMiddleware($middlewareQueue);
      Nach dem Login kopieren
      Im Code verwenden wir das MailerAwareTrait, das mit CakePHP geliefert wird, um E-Mails zu versenden. Wir haben auch eine SMS über die Twilio-API gesendet. „notification“ im Code stellt die E-Mail-Vorlage dar, die wir im Mailers-Verzeichnis erstellt haben, und $data stellt die an die E-Mail-Vorlage übergebenen Daten dar.

      Middleware registrieren:

      Damit die Middleware funktioniert, müssen wir sie bei der Anwendung registrieren. Wir können dies tun, indem wir der Datei bootstrap.php den folgenden Code hinzufügen:

      rrreee🎜Auf diese Weise registrieren wir die NotificationMiddleware in der Middleware-Warteschlange der Anwendung. 🎜🎜Fazit: 🎜Durch die Verwendung der CakePHP-Middleware können wir E-Mail- und SMS-Dienste problemlos integrieren, um Nachrichtenbenachrichtigungsfunktionen zu implementieren. Dieser Artikel enthält einige Codebeispiele, die Ihnen hoffentlich dabei helfen werden, ähnliche Funktionen in Ihren eigenen Projekten zu implementieren. Selbstverständlich können Sie diese Codes auch nach Ihren Bedürfnissen erweitern und anpassen. Viel Glück beim Erstellen leistungsstarker und umfassender Webanwendungen mit CakePHP! 🎜

      Das obige ist der detaillierte Inhalt vonCakePHP-Middleware: Integrieren Sie E-Mail- und SMS-Dienste, um Nachrichtenbenachrichtigungen zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage