Heim  >  Artikel  >  Backend-Entwicklung  >  „Spezifikationen“ für die Entwicklung der Funktion zum Senden von SMS-Bestätigungscodes in Laravel (Bild)

„Spezifikationen“ für die Entwicklung der Funktion zum Senden von SMS-Bestätigungscodes in Laravel (Bild)

黄舟
黄舟Original
2017-10-27 09:02:441474Durchsuche

Laravel ist ein einfaches und elegantes PHP-Webentwicklungs-Framework (PHP Web Framework). Als nächstes werde ich Ihnen in diesem Artikel die „standardisierte“ Entwicklungs-SMS-Verifizierungscode-Sendefunktion in Laravel vorstellen. Freunde, die sie benötigen, können sich darauf beziehen

Einführung in Laravel

Laravel ist ein einfaches und elegantes PHP-Webentwicklungs-Framework (PHP Web Framework). Es kann Sie von unordentlichen Codes wie Nudeln befreien; es kann Ihnen helfen, eine perfekte Netzwerk-APP zu erstellen, und jede Codezeile kann prägnant und ausdrucksstark sein.

Laravel verfügt bereits über eine erweiterte PHP ActiveRecord-Implementierung – Eloquent ORM. Es kann problemlos „Einschränkungen“ auf beide Seiten der Beziehung anwenden, sodass Sie die vollständige Kontrolle über die Daten haben und alle Annehmlichkeiten von ActiveRecord genießen können. Eloquent unterstützt nativ alle Methoden des Abfrage-Builders (query-builder) in Fluent.

„Standard“-Entwicklung der SMS-Verifizierungscode-Sendefunktion in LaravelBedarfsszenarien

Senden Sie einen „Bestätigungscode“ oder eine „Nachrichtenbenachrichtigung“ an Ihr Mobiltelefon oder Ihre E-Mail.

Vollständig

Zunächst besteht die Spezifikation in Laravel darin, die „Nachrichtenbenachrichtigung“ von Laravel zu verwenden. Hier lautet das Szenario „Bestätigungscode“. . Diese Anforderung wird von fast allen Softwaresystemen genutzt.

Benachrichtigungsszene erstellen

Der erste Schritt besteht darin, mit php artisan make:notification eine Benachrichtigungsklasse zu erstellen. Drei davon sind standardmäßig bereits vorhanden. Da der Verifizierungscode gesendet wird, heißt diese Kontrollklasse VerificationCode.

Erstellen Sie dann ein Verifizierungscode-Datenmodell und eine Datentabellenmigration. Sie können php artisan make:model „VerificationCode“ -m verwenden, um das Datenmodell schnell zu erstellen und direkt zu migrieren.

Die Migration von ThinkSNS+ läuft wie folgt ab:

Der zweite Schritt besteht darin, die Datenmodellklasse zu öffnen und das Merkmal IlluminateNotificationsNotifiable hinzuzufügen darin:

Aus dem Code können Sie ersehen, dass wir auch „sanftes Löschen“ hinzugefügt haben, da der Bestätigungscode basierend auf der Mobiltelefonnummer oder E-Mail gesendet wird. Es sind keine weiteren integrierten Tricks erforderlich. Es ist nicht erforderlich, es in der „Message Notification Data Table“ aufzuzeichnen. Daher entscheiden wir uns dafür, das Konto (Mobiltelefonnummer oder E-Mail-Adresse) direkt zurückzugeben, das benötigt wird gesendet werden.

Factory-Modus beitreten, schnell senden

Datenbank/factories/ModelFactory.php öffnen und eine Benachrichtigung darüber hinzufügen Fabrikdefinition des Datenmodells:

Auf diese Weise können wir schnell Verifizierungscodes erstellen und Benachrichtigungen über die Fabrikfunktion (ZhiyiPlusModelsVerificationCode::class) senden.

Warum wird die Benachrichtigungseigenschaft zum Bestätigungscode-Datenmodell hinzugefügt?

Zuallererst fügt Laravel dem Benutzermodell standardmäßig die Eigenschaft IlluminateNotificationsNotifiable hinzu, sodass Sie über $user->notify() schnell eine Benachrichtigung an den Benutzer senden können, aber in der Spezifikation gibt es diesen Satz Dokument:

Denken Sie daran, dass Sie die Eigenschaft IlluminateNotificationsNotifiable für jedes Ihrer Modelle verwenden können. Sie sind nicht darauf beschränkt, sie nur in Ihr Benutzermodell aufzunehmen.

Dies ist der Originaltext des offiziellen Laravel-Dokuments , was bedeutet, dass IlluminateNotificationsNotifiable nicht nur für das Benutzermodell gilt.

Unsere Hinzufügung von IlluminateNotificationsNotifiable im Verifizierungscode-Modell steht also vollständig im Einklang mit der korrekten Verwendung von Laravel-Benachrichtigungen.

Benachrichtigungsklasse entwickeln

Zunächst gibt es einen Feldkanal in der Datentabellenmigration, nämlich die Benachrichtigungskanal-ID We Sie können diesen Wert verwenden, um zu entscheiden, wie der Bestätigungscode gesendet werden soll. Dieser Vorgang wird im Via der Benachrichtigungsklasse implementiert:

Die von uns gewählte Methode besteht darin, den direkt zurückzugeben Kanalwert, der ein beliebiger Wert sein kann. Solange wir diesen Benachrichtigungskanal implementieren, können wir ihn senden, und Laravel verfügt über einige integrierte Sendekanäle Datenbank, E-Mail und Nexmo

Vollständig Senden des E-Mail-Bestätigungscodes

Eigentlich müssen wir in diesem Schritt nur sehr wenige Dinge tun. Bei der Erstellung der Benachrichtigungsklasse ist die toMail-Methode abgeschlossen, sodass wir sie direkt ändern können den Nachrichteninhalt.

Versenden des SMS-Bestätigungscodes abschließen

Wir verwenden zum Senden von SMS das Overtrue/Easy-Sms-Paket, einen von An Zhengchao entwickelten SMS-Versand-Client . Es gibt viele integrierte SMS-Plattformen und auch die Implementierung ist hervorragend. (Tucao: Obwohl einige Details problematisch sind, z. B. die Nichtübergabe des Gateways gemäß der Vertragsaufrufmethode)

Verlassen Sie sich zunächst auf SMS, um dem Client-Paket Composer die Anforderung overtrue/easy-sms zu senden, und erstellen Sie dann eine neue Konfiguration /config/sms.php, was ist der Inhalt? Befolgen Sie einfach die Anweisungen auf der Easy-SMS-Homepage, um ihn hinzuzufügen. Um die Anzahl der Wörter im Artikel zu reduzieren, behalten Sie nur die Alibaba-Konfiguration bei ):

Wir haben eine Kanalkonfiguration für verschiedene Szenarien hinzugefügt, wie z. B. einen Verifizierungscode-Szenariocode, um den Nachrichtengeber zu erleichtern Lesen Sie die Konfiguration .

Dann öffnen Sie AppServiceProvider.php und fügen Sie Folgendes im Register hinzu:

Zu diesem Zeitpunkt ist die Integration von EasySms in Laravel abgeschlossen, aber die eigentliche Die Funktion wurde noch nicht entwickelt.

SMS-Sendekanal entwickeln

Warum entwickeln? Erstens unterstützt easy-sms eine Menge von Funktionen, die Sie für jede einzelne Sendeplattform entwickeln können, oder Sie können nur eine Klasse für den SMS-Sendekanal entwickeln. SMS-Strategie. Mechanismus zum Senden von Bestätigungscodes an mehrere Plattformen.

Erstellen Sie zunächst eine neue Datei app/Notifications/Channels/SmsChannel.php. Da Laravel keine Generierungsfunktion bereitstellt, müssen Sie diese einfach selbst erstellen. Der Inhalt von SmsChannel lautet wie folgt:

Der auf Easy-Sms basierende Kanal zum Senden von SMS-Benachrichtigungen wurde fertiggestellt.

EntwicklungsszenarioNachricht senden

Dieser Teil gehört vollständig zur Easy-SMS-Entwicklung, wir erstellen eine neue VerificationCodeMessage. php, der Inhalt ist wie folgt:

Dann kehren wir zur VerificationCode-Benachrichtigungsklasse zurück und fügen die toSms-Methode hinzu:

Szenariokonfiguration, z. B. Vorlagen für verschiedene Verifizierungscodekanäle usw., damit der Nachrichtengeber anhand des sendenden Gateways bestimmen kann, welche Nutzungsszenariokonfiguration vorliegt.

Beschweren Sie sich noch einmal, das Vertragsdesign von easy-sms sollte diese Idee auch haben, aber getContent/getTemplate/getData passiert das Gateway überhaupt nicht, wenn das eigentliche Gateway aufgerufen wird. . .

Okay, unsere Entwicklung ist abgeschlossen.

Bestätigungscode senden

Er wurde beim Erstellen des Bestätigungscode-Datenmodells zur „Fabrik“ hinzugefügt, sodass wir die Fabrik direkt verwenden können Funktion, Demo senden:

Fertig, easy-sms ist ein sehr gutes Paket.

Das obige ist der detaillierte Inhalt von„Spezifikationen“ für die Entwicklung der Funktion zum Senden von SMS-Bestätigungscodes in Laravel (Bild). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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