Heim >Backend-Entwicklung >Golang >Vereinfachen der String-Validierung in Go: Einführung von validatorgo
Eine Bibliothek von String-Validatoren und Sanitizern, basierend auf der js-Bibliothek validator.js
Warum nicht beliebte Go-Bibliotheken wie Package Validator oder Govalidator verwenden? Obwohl beide Bibliotheken bekannt sind, konzentriert sich validatorgo auf die eigenständige String-Validierung und bietet eine umfangreiche Sammlung anpassbarer Validatoren, die von validator.js inspiriert sind, die keine dieser Go-Bibliotheken vollständig implementiert.
So hebt sich validatorgo im Vergleich zu go-playground/validator und govalidator ab:
Direkte String-Validierung: go-playground/validator wurde in erster Linie für die Validierung von Strukturfeldern mithilfe von Tags entwickelt, was sich ideal für die Verarbeitung von JSON- oder strukturbasierten Daten eignet. Es ist jedoch nicht für die Validierung einzelner Zeichenfolgen konzipiert, was ValidatorGo nahtlos erledigt, ohne dass Struktur-Tags oder zusätzliche Einrichtung erforderlich sind.
Leistung: go-playground/validator verlässt sich auf Reflektion, um Struktur-Tags dynamisch zu überprüfen. Obwohl die Reflexion leistungsstark ist, kann sie zu Leistungseinbußen führen – insbesondere, wenn große oder komplexe Datenstrukturen validiert werden. validatorgo vermeidet Reflexionen, was die Leistung steigert und es schneller und effizienter für Szenarien macht, in denen Einzelfeldvalidierungen erforderlich sind.
Ich habe validatorgo erstellt, um als Abhängigkeit für eine andere Go-Bibliothek namens ginvalidator zu dienen, die HTTP-Anfragen in Go-Webanwendungen validiert. Inspiriert von Express-Validator, der beliebten Validierungsbibliothek für Node.js und Express, füllt ValidatorGo eine Lücke im Go-Ökosystem für eine effiziente, anpassbare und unkomplizierte String-Validierung. Da andere Bibliotheken entweder übertrieben waren, ihnen die Funktionalität fehlte oder sie meinen Anwendungsfall nicht erfüllten, habe ich validatorgo entwickelt, um eine praktische Lösung anzubieten.
Mit go get.
go get github.com/bube054/validatorgo
Dann importieren Sie das Paket in Ihren eigenen Code.
import ( "fmt" "github.com/bube054/validatorgo" )
Wenn Sie mit der Verwendung des langen validatorgo-Paketnamens nicht zufrieden sind, können Sie dies tun.
go get github.com/bube054/validatorgo
import ( "fmt" "github.com/bube054/validatorgo" )
Nachfolgend finden Sie eine Liste der Validatoren, die vom validatorgo-Paket bereitgestellt werden. Es deckt verschiedene String-Formate und -Typen ab und ist somit vielseitig für mehrere Validierungsanforderungen geeignet.
Validator | Beschreibung |
---|---|
Enthält | Überprüft, ob eine Zeichenfolge eine angegebene Teilzeichenfolge enthält. |
Gleich | Überprüft, ob eine Zeichenfolge genau einer Vergleichszeichenfolge entspricht. |
IsAbaRouting | Überprüft, ob es sich bei der Zeichenfolge um eine gültige ABA-Routennummer (US-Bankkonten) handelt. |
IstNachher | Überprüft, ob eine Datumszeichenfolge nach einem angegebenen Datum liegt. |
IsAlpha | Stellt sicher, dass die Zeichenfolge nur Buchstaben (a-zA-Z) enthält. |
IstAlphanumerisch | Überprüft, ob eine Zeichenfolge nur Buchstaben und Zahlen enthält. |
IsAscii | Überprüft, ob die Zeichenfolge nur ASCII-Zeichen enthält. |
IsBase32 | Überprüft, ob die Zeichenfolge ein gültiger Base32-codierter Wert ist. |
IsBase64 | Überprüft, ob eine Zeichenfolge in Base64-Codierung vorliegt. |
IstBefore | Stellt sicher, dass das Datum vor einem bestimmten Datum liegt. |
IsBoolean | Überprüft, ob die Zeichenfolge entweder „wahr“ oder „falsch“ ist. |
IsCreditCard | Überprüft, ob es sich bei der Zeichenfolge um eine gültige Kreditkartennummer handelt. |
IstCurrency | Überprüft, ob die Zeichenfolge ein gültiges Währungsformat hat. |
IstDatum | Überprüft, ob eine Zeichenfolge ein gültiges Datum ist. |
IsDecimal | Stellt sicher, dass die Zeichenfolge eine gültige Dezimalzahl darstellt. |
IsEmail | Überprüft, ob die Zeichenfolge ein gültiges E-Mail-Adressformat hat. |
IstEmpty | Überprüft, ob eine Zeichenfolge leer ist. |
IsFQDN | Überprüft, ob die Zeichenfolge ein vollständig qualifizierter Domänenname ist. |
IsFloat | Stellt sicher, dass die Zeichenfolge eine Gleitkommazahl darstellt. |
IsHexColor | Überprüft, ob eine Zeichenfolge eine gültige Hex-Farbe hat (z. B. #FFFFFF). |
IsIP | Überprüft, ob die Zeichenfolge eine gültige IP-Adresse (IPv4 oder IPv6) ist. |
Ist ISO8601 | Überprüft, ob die Zeichenfolge im ISO8601-Datumsformat vorliegt. |
IsLength | Überprüft, ob die Länge der Zeichenfolge innerhalb eines angegebenen Bereichs liegt. |
IsMimeType | Überprüft, ob die Zeichenfolge ein gültiger MIME-Typ ist. |
IstMobilePhone | Überprüft, ob die Zeichenfolge eine gültige Mobiltelefonnummer für bestimmte Gebiete ist. |
IsMongoID | Überprüft, ob die Zeichenfolge eine gültige MongoDB-Objekt-ID ist. |
IsNumeric | Stellt sicher, dass die Zeichenfolge nur numerische Zeichen enthält. |
IsPostalCode | Überprüft, ob die Zeichenfolge eine gültige Postleitzahl für das angegebene Gebietsschema ist. |
IstRFC3339 | Überprüft, ob die Zeichenfolge im RFC3339-Datumsformat vorliegt. |
IsSlug | Überprüft, ob die Zeichenfolge URL-freundlich ist (nur Buchstaben, Zahlen und Bindestriche). |
IsStrongPassword | Stellt sicher, dass die Zeichenfolge den allgemeinen Anforderungen an die Passwortstärke entspricht. |
IsURL | Überprüft, ob die Zeichenfolge eine URL ist. |
IsUUID | Überprüft, ob die Zeichenfolge eine gültige UUID ist (Versionen 1–5). |
IsUpperCase | Stellt sicher, dass die Zeichenfolge ausschließlich aus Großbuchstaben besteht. |
IstMehrwertsteuer | Überprüft, ob die Zeichenfolge eine gültige Umsatzsteuer-Identifikationsnummer für bestimmte Länder ist. |
Übereinstimmungen | Überprüft, ob die Zeichenfolge mit einem angegebenen regulären Ausdruck übereinstimmt. |
Diese Tabelle sollte die meisten Validatoren abdecken, die derzeit in validatorgo verfügbar sind. Weitere Informationen zur Verwendung jedes Validators finden Sie in der Dokumentation des Pakets.
⚠ Achtung
Wenn Sie einen Validator verwenden, der eine Optionsstruktur erfordert (entweder einen Zeiger oder einen Nicht-Zeiger), geben Sie immer explizit Werte für alle Strukturfelder an.
Anders als in validator.js, wo fehlende Felder automatisch auf Standardwerte gesetzt werden, verwendet Go strenge Typen.
Dies bedeutet, dass fehlende Werte für boolesche Werte standardmäßig auf „false“, für Zahlentypen auf „0“ usw. gesetzt werden.
Wenn Sie nicht alle Felder angeben, kann es zu unerwartetem Verhalten kommen, wenn Sie mit der JavaScript-Version vertraut sind.
Beispiele
go get github.com/bube054/validatorgo
import ( "fmt" "github.com/bube054/validatorgo" )
Sanitizer | Description |
---|---|
Trim | Removes whitespace from both ends of the string. |
LTrim | Removes whitespace from the left side of the string. |
RTrim | Removes whitespace from the right side of the string. |
ToLower | Converts the entire string to lowercase. |
ToUpper | Converts the entire string to uppercase. |
Escape | Escapes HTML characters in the string to prevent injection attacks. |
Unescape | Reverts escaped HTML characters back to normal characters. |
NormalizeEmail | Standardizes an email address, e.g., removing dots in Gmail addresses. |
Blacklist | Removes characters from the string that match specified characters or patterns. |
Whitelist | Retains only characters in the string that match specified characters or patterns. |
Replace | Replaces occurrences of a substring with a specified replacement. |
StripLow | Removes control characters, optionally allowing some specified ones. |
TrimSpace | Trims all types of whitespace from both ends of the string. |
ToBoolean | Converts common truthy and falsy values in strings into boolean true or false. |
ToInt | Converts a numeric string into an integer, if possible. |
ToFloat | Converts a numeric string into a floating-point number, if possible. |
Diese Desinfektionsmittel werden häufig verwendet, um die Datenkonsistenz und -sicherheit zu gewährleisten, indem potenziell unerwünschte oder gefährliche Zeichen entfernt oder geändert werden.
Beachten Sie unbedingt die offizielle Validatorgo-Dokumentation für spezifische Implementierungen und Beispiele für jedes Desinfektionsmittel.
validatorgo ist die ideale Wahl, wenn Sie Folgendes benötigen:
Mit validatorgo erhalten Sie ein Tool, das speziell für die String-Validierung entwickelt wurde und sowohl Standalone- als auch Webanwendungsanforderungen in Go unterstützt.
Das obige ist der detaillierte Inhalt vonVereinfachen der String-Validierung in Go: Einführung von validatorgo. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!