Heim > Artikel > Backend-Entwicklung > Entwickeln Sie eine Funktion zum Senden von SMS-Bestätigungscodes über den Laravel-Standard.
Laravel ist ein einfaches und elegantes PHP-Webentwicklungs-Framework (PHP Web Framework). Als nächstes werde ich Ihnen in diesem Artikel die „Standard“-Funktion zum Senden von SMS-Bestätigungscodes 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 darin das Merkmal IlluminateNotificationsNotifiable hinzuzufügen:
Anhand des Codes können Sie erkennen, dass wir auch das „sanfte Löschen“ hinzugefügt haben. Da der Bestätigungscode auf der Grundlage der Mobiltelefonnummer oder E-Mail-Adresse gesendet wird, ist dies nicht erforderlich Es gibt keine anderen integrierten Tricks und es ist auch nicht erforderlich, die „Nachricht“ „Benachrichtigungsdatentabelle“ aufzuzeichnen. Daher entscheiden wir uns in der RouteNotificationFor-Methode dafür, das Konto (Mobiltelefonnummer oder E-Mail-Adresse) direkt zurückzugeben, das gesendet werden muss.
Factory-Modus betreten und schnell senden
Datenbank/factories/ModelFactory.php öffnen und eine Factory-Definition über das Benachrichtigungsdatenmodell hinzufügen:
Auf diese Weise können wir schnell Verifizierungscodes erstellen und Benachrichtigungen über die Factory-Funktion (ZhiyiPlusModelsVerificationCode::class) senden.
Warum wird die Benachrichtigungseigenschaft zum Bestätigungscode-Datenmodell hinzugefügt?
Zuallererst fügt Laravel standardmäßig die Eigenschaft IlluminateNotificationsNotifiable zum Benutzermodell hinzu, sodass $user->notify() schnell eine Benachrichtigung an den Benutzer senden kann, aber im Spezifikationsdokument gibt es diesen Satz:
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 bedeutet IlluminateNotificationsNotifiable Nicht nur für das Benutzermodell.
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.
Versand des SMS-Bestätigungscodes vervollständigen
Wir verwenden das Paket overtrue/easy-sms zum Versenden von Textnachrichten. Dies ist ein von An Zhengchao entwickelter Client zum Versenden von Textnachrichten. Er verfügt über viele integrierte Textnachrichtenplattformen und seine Implementierung ist ebenfalls 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, z. B. einen Verifizierungscode-Szenariocode, um dem Nachrichtengeber das Lesen der Konfiguration zu erleichtern .
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 können Sie mit easy-sms eine separate Klasse für den Versand von Benachrichtigungen für jede Versandplattform entwickeln oder nur eine Klasse für den Versand von SMS-Benachrichtigungen 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.
Entwicklungsszenario zum Versenden von Nachrichten
Dieser Teil gehört ausschließlich zur easy-sms-Entwicklung. Wir erstellen eine neue VerificationCodeMessage.php mit folgendem Inhalt :
Dann gehen wir zurück zur Verifizierungscode-Benachrichtigungsklasse und fügen die toSms-Methode hinzu. Mein Code lautet wie folgt:
Szenenkonfiguration, z. B. Vorlagen für verschiedene Verifizierungscodekanäle usw., damit der Nachrichtenserver die Konfiguration des Nutzungsszenarios basierend auf dem sendenden Gateway bestimmen kann.
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.
Die oben genannten Codes stammen alle von ThinkSNS Plus
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er für das Lernen aller hilfreich ist PHP chinesische Website!
Verwandte Empfehlungen:
Benutzerregistrierung und Anmeldung über Laravel
Erfahren Sie, wie Sie Arrays zur Ansicht im Laravel5-Framework übertragen
Das obige ist der detaillierte Inhalt vonEntwickeln Sie eine Funktion zum Senden von SMS-Bestätigungscodes über den Laravel-Standard.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!