Heim > Backend-Entwicklung > Golang > Vereinfachen der String-Validierung in Go: Einführung von validatorgo

Vereinfachen der String-Validierung in Go: Einführung von validatorgo

Linda Hamilton
Freigeben: 2024-11-14 20:20:02
Original
501 Leute haben es durchsucht

Simplifying String Validation in Go: Introducing validatorgo

Eine Bibliothek von String-Validatoren und Sanitizern, basierend auf der js-Bibliothek validator.js

Warum sollten Sie sich für validatorgo entscheiden?

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:


1. Im Vergleich zu Go-Playground/Validator

  • 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.


2. Im Vergleich zu asaskevich/govalidator

  • Anpassung und Flexibilität: govalidator bietet eine Reihe von Validatoren für Strings, aber validatorgo erhöht die Flexibilität, indem es spezifische Optionen und Konfigurationen für einzelne Validatoren zulässt. Beispielsweise können Datumsformate oder Gebietsschemaspezifikationen angepasst werden, was Entwicklern mehr Kontrolle über Validierungsregeln gibt, die auf die Projektanforderungen zugeschnitten sind.

Projektmotivation

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.

Installation

Mit go get.

 go get github.com/bube054/validatorgo
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Dann importieren Sie das Paket in Ihren eigenen Code.

 import (
   "fmt"
   "github.com/bube054/validatorgo"
 )
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Wenn Sie mit der Verwendung des langen validatorgo-Paketnamens nicht zufrieden sind, können Sie dies tun.

 go get github.com/bube054/validatorgo
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Einfaches Validator-Beispiel

 import (
   "fmt"
   "github.com/bube054/validatorgo"
 )
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Einige Validatoren

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
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Einfaches Beispiel für ein Desinfektionsmittel

 import (
   "fmt"
   "github.com/bube054/validatorgo"
 )
Nach dem Login kopieren
Nach dem Login kopieren
Nach dem Login kopieren

Desinfektionsmittel

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.

Zusammenfassung

validatorgo ist die ideale Wahl, wenn Sie Folgendes benötigen:

  • Effiziente, reflexionsfreie Validierungen für einzelne Felder ohne die Leistungskosten, die mit strukturbasierter Reflexion verbunden sind.
  • Hochgradig anpassbare Validierungsoptionen, die sich an moderne Datenformate anpassen und die gleiche Robustheit wie validator.js bieten.

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.

Betreuer

  • bube054 – Attah Gbubemi David (Autor)

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!

Quelle:dev.to
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage