Überprüfen von Telefonnummern in einer Spring Boot-App mit der Twilio Lookup-API
Viele Benutzerregistrierungsabläufe fordern heutzutage Benutzer auf, ihre Telefonnummer einzugeben. Diese wird entweder für die Zwei-Faktor-Authentisierung oder zum Bereitstellen von Benachrichtigungen und Updates verwendet.
Um zu überprüfen, ob die vom Benutzer bereitgestellte Nummer auch gültig ist, sind wir vielleicht versucht, auf einen regulären Ausdruck zurückzugreifen. Das ist allerdings nicht zuverlässig. Telefonnummern sind eine komplizierte Angelegenheit, und ein regulärer Ausdruck gibt uns keine Auskunft darüber, ob die angegebene Nummer auch tatsächlich erreichbar ist. Es gibt mehrere Ebenen der Überprüfung. In diesem Blog zeige ich, wie wir mit Twilio Lookup-API die Gültigkeit einer Telefonnummer überprüfen können.
Für die Demo-Anwendung verwenden wir Spring Boot. Anhand des Bean Validation-Frameworks zeige ich, wie wir eine @ValidPhoneNumber
-Annotation erstellen. Diese kann ähnlich wie @NotNull
verwendet werden.
Voraussetzungen
Bevor wir beginnen, benötigen wir Folgendes:
- Ein Twilio-Konto. Wenn du dich über diesen Link registrierst, erhältst du ein Guthaben von 10 $ bei einem Upgrade des Kontos.
- Installiertes Java (Java 8 oder höher). Meine bevorzugte Methode zur Installation von Java ist mit SDKMAN!
- git
Wir beginnen mit dem Klonen des Demo-Repositorys aus GitHub am no-validation
-Tag:
Mit dem Befehl ./mvnw spring-boot:run
starten wir die Anwendung. Wir wissen, dass die Anwendung ausgeführt wird, wenn die Protokollmeldungen in der Zeile, die Started PhoneNumberLookupDemoApplication
enthält, enden.
Jetzt können wir http://localhost:8080 aufrufen. Wir sollten Folgendes sehen:
Wenn wir versuchen, auf die Schaltfläche „Submit“ (Senden) zu klicken, ohne einen Namen oder eine Telefonnummer einzugeben, erhalten wir Fehlermeldungen. Wenn wir in beide Felder entsprechende Werte eingeben, wird uns die andere Seite in dieser App angezeigt:
Sehen wir uns an, wie diese Überprüfung im Servercode konfiguriert wurde. Wir öffnen über unsere IDE die Person
-Klasse im lol.gilliard.twiliolookupdemo
-Paket. Uns wird der folgende Codeabschnitt angezeigt:
Diese Annotationen sind Teil des von Spring verwendeten Bean Validation-Frameworks beim Erstellen eines Person
-Objekts aus den Feldern im Formular. Folgendes Problem tritt dabei auf. Wenn wir nur @NotBlank
im phoneNumber
-Feld verwenden, überprüft die App nicht, ob es sich bei der Telefonnummer überhaupt um eine Nummer handelt, geschweige denn eine gültige Telefonnummer.
Für eine bessere Überprüfung können wir die benutzerdefinierte Annotation @ValidPhoneNumber
erstellen, die mithilfe der Twilio Lookup-API die Gültigkeit einer Telefonnummer überprüft.
Verbesserte Überprüfung mit der Twilio Lookup-API
Wir müssen zwei neue Klassen erstellen und einige Konfigurationen vornehmen:
- Eine Annotation mit dem Namen
ValidPhoneNumber
, die zum Markieren desphoneNumber
-Felds in derPerson
-Klasse verwendet werden kann. - Eine Klasse, die
ConstraintValidator
implementiert. Dieser enthält den Code zum Durchführen der Überprüfung. - Unsere Twilio-Kontodetails werden für die Authentifizierung von der Lookup-API benötigt.
Anschließend können wir diese Annotation in der Person
-Klasse verwenden.
Erstellen der Annotation
Wir erstellen in demselben Paket, in dem sich die anderen Klassen befinden, eine neue Datei mit dem Namen ValidPhoneNumber.java
, die den Code für die Annotation enthält. Annotationen werden mit dem @interface
-Schlüsselwort deklariert. Der Code für die Annotation lautet:
[vollständiger Code, einschließlich Importe, auf GitHub]
Das ist die Standardmethode zum Erstellen einer Annotation für das Bean Validation-Framework. Sie mag zwar etwas kompliziert erscheinen, aber die zwei wichtigsten Stellen sind hier hervorgehoben:
- die
@Constraint
-Annotation, die die Klasse angibt, die den Code zum Durchführen der Überprüfung enthält - die Standardnachricht, die überschrieben werden kann, wie wir später noch sehen werden
Erstellen der Überprüfung
Wir erstellen die PhoneNumberValidator
-Klasse in demselben Paket und fügen den folgenden Inhalt ein:
[vollständiger Code, einschließlich Importe, auf GitHub]
Die isValid
-Methode muss true
zurückgeben, wenn der Wert eine gültige Telefonnummer ist. Dazu müssen wir allerdings ein paar Schritte ausführen. Zuerst müssen wir von der vom Benutzer eingegebenen Nummer alle nicht erforderlichen Zeichen entfernen:
Für gewöhnlich werden Telefonnummern mit Leerzeichen, Klammern und Bindestrichen geschrieben, um die Zahlen zu gruppieren. Die Lookup-API erwartet allerdings eine Eingabe im E.164-Format. Dabei handelt es sich um ein Standardformat für internationale Telefonnummern, die mit einem +
beginnen und nur Zahlen enthalten, keine anderen Leerzeichen oder Sonderzeichen.
Wenn der Benutzer keine Eingabe macht, können wir davon ausgehen, dass es keine gültige Telefonnummer ist. Deshalb brechen wir hier ab, um uns einen API-Aufruf zu sparen. Ein Vergleich mit einer leeren Zeichenfolge ist hier in Ordnung, aber wenn wir Java 11 verwenden würden, wäre String#isBlank()
angebracht:
Jetzt ist es ist an der Zeit, die Lookup-API aufzurufen. Das erreichen wir mit dem folgenden Code:
Wenn die Telefonnummer nicht gültig ist, gibt die Lookup-API eine Fehlermeldung 404 zurück, die im Code als eine ApiException
auftaucht. Wenn return true
zurückgegeben wird, handelt es sich um eine gültige Telefonnummer. Falls dies nicht der Fall ist, geben wir den catch
-Block ein und geben „false“ zurück, wenn der Antwortcode 404 lautet.
Konfigurieren des Twilio-Clients
Wir fügen der App unsere Anmeldeinformationen für das Twilio-Konto hinzu. Dann geben wir die Werte unter src/main/resources/application.properties
ein. Diese finden wir in unserer Twilio-Konsole.
Diese Werte werden durch Spring zur Laufzeit in den PhoneNumberValidator
eingefügt.
Verwenden der Überprüfung
Endlich sind wir soweit, die von uns erstellte Überprüfung einzusetzen. Wir ersetzen in der Person-Klasse:
durch
Anhand dieses Vorgangs können wir auch die Standardnachricht für einen Fehler bei der Überprüfung überschreiben.
Testen der Überprüfung
Wir starten unsere Anwendung neu und testen sie noch einmal. Wir beenden den Server, den wir zuvor ausgeführt haben, und führen mit dem Befehl ./mvnw spring-boot:run einen Neustart durch. Jetzt sollten wir nur fortfahren können, indem wir eine gültige Telefonnummer eingeben. Wenn wir uns außerhalb der USA befinden, dürfen wir die internationale Vorwahlnummer nicht vergessen.
Zusammenfassung
In diesem Blog haben wir eine Spring Boot-Anwendung mit einer benutzerdefinierten Überprüfung erstellt. Für die Überprüfung haben wir das Bean Validation-Framework verwendet, das die Twilio Lookup-API aufruft, um die Gültigkeit einer Telefonnummer zu überprüfen. Keine leichte Aufgabe, deshalb dürfen wir uns jetzt selbst kurz auf die Schulter klopfen.
Dieser Code prüft natürlich nicht, ob die Telefonnummer auch tatsächlich der Person gehört, die das Formular ausfüllt. Weitere Informationen dazu findest du in der Dokumentation zur Verify-API. Und wenn du mehr dazu erfahren möchtest, wie Twilio bei der Sicherheit helfen kann, sieh dir die Informationen zu Authy an.
Wenn du an einer weiteren Entwicklung mit Twilio und Java interessiert bist, können dir unsere Schnellstarts und die Java-Beiträge in unserem Blog weiterhelfen. Wie immer bin ich gespannt auf deine Ergebnisse. Du findest mich auf Twitter unter @MaximumGilliard oder sende eine E-Mail an mgilliard@twilio.com.
Verwandte Posts
Ähnliche Ressourcen
Twilio Docs
Von APIs über SDKs bis hin zu Beispiel-Apps
API-Referenzdokumentation, SDKs, Hilfsbibliotheken, Schnellstarts und Tutorials für Ihre Sprache und Plattform.
Ressourcen-Center
Die neuesten E-Books, Branchenberichte und Webinare
Lernen Sie von Customer-Engagement-Experten, um Ihre eigene Kommunikation zu verbessern.
Ahoy
Twilios Entwickler-Community-Hub
Best Practices, Codebeispiele und Inspiration zum Aufbau von Kommunikations- und digitalen Interaktionserlebnissen.