Rumah >pembangunan bahagian belakang >Golang >Mempermudahkan Pengesahan Rentetan dalam Go: Memperkenalkan validatorgo
Pustaka pengesah rentetan dan pembersih, berdasarkan pengesah perpustakaan js.js
Mengapa tidak menggunakan perpustakaan Go yang popular seperti Package validator atau govalidator? Walaupun kedua-dua pustaka terkenal, validatorgo memfokuskan pada pengesahan rentetan kendiri dan menyediakan koleksi luas pengesah yang boleh disesuaikan yang diilhamkan oleh validator.js, yang mana satu pun daripada perpustakaan Go ini tidak melaksanakan sepenuhnya.
Begini cara validatorgo menonjol berbanding dengan go-playground/validator dan govalidator:
Pengesahan Rentetan Langsung: go-playground/validator terutamanya dibina untuk mengesahkan medan struct menggunakan teg, yang sesuai untuk mengendalikan JSON atau data berasaskan struct. Walau bagaimanapun, ia tidak direka untuk mengesahkan rentetan individu, yang ValidatorGo lakukan dengan lancar, tanpa memerlukan teg struct atau persediaan tambahan.
Prestasi: go-playground/validator bergantung pada pantulan untuk memeriksa teg struct secara dinamik. Walaupun berkuasa, refleksi boleh memperkenalkan overhed prestasi—terutamanya apabila struktur data yang besar atau kompleks disahkan. validatorgo mengelakkan refleksi, yang meningkatkan prestasi, menjadikannya lebih pantas dan lebih cekap untuk senario di mana pengesahan medan tunggal diperlukan.
Saya mencipta validatorgo untuk berfungsi sebagai pergantungan bagi pustaka Go lain yang dipanggil ginvalidator, yang mengesahkan permintaan HTTP dalam aplikasi web Go. Diinspirasikan oleh express-validator, pustaka pengesahan popular untuk Node.js dan Express, ValidatorGo mengisi jurang dalam ekosistem Go untuk pengesahan rentetan yang cekap, boleh disesuaikan dan mudah. Memandangkan perpustakaan lain sama ada berlebihan, tidak mempunyai fungsi atau tidak memenuhi kes penggunaan saya, saya membina validatorgo untuk menawarkan penyelesaian praktikal.
Menggunakan go get.
go get github.com/bube054/validatorgo
Kemudian import pakej ke dalam kod anda sendiri.
import ( "fmt" "github.com/bube054/validatorgo" )
Jika anda tidak berpuas hati menggunakan nama pakej validatorgo yang panjang, anda boleh melakukannya.
go get github.com/bube054/validatorgo
import ( "fmt" "github.com/bube054/validatorgo" )
Di bawah ialah senarai pengesah yang disediakan oleh pakej validatorgo, yang merangkumi pelbagai format dan jenis rentetan, menjadikannya serba boleh untuk pelbagai keperluan pengesahan.
Pengesah | Penerangan |
---|---|
Mengandungi | Menyemak sama ada rentetan mengandungi subrentetan tertentu. |
Sama dengan | Mengesahkan jika rentetan betul-betul sama dengan rentetan perbandingan. |
IsAbaRouting | Menyemak sama ada rentetan itu ialah nombor penghalaan ABA yang sah (akaun bank AS). |
IsAfter | Mengesahkan jika rentetan tarikh adalah selepas tarikh yang ditentukan. |
IsAlpha | Memastikan rentetan hanya mengandungi huruf (a-zA-Z). |
AdalahAlfanumerik | Mengesahkan jika rentetan mengandungi huruf dan nombor sahaja. |
IsAscii | Menyemak sama ada rentetan mengandungi aksara ASCII sahaja. |
IsBase32 | Menyemak sama ada rentetan itu ialah nilai yang dikodkan Base32 yang sah. |
IsBase64 | Mengesahkan jika rentetan berada dalam pengekodan Base64. |
Sebelumnya | Memastikan tarikh sebelum tarikh yang ditetapkan. |
IsBoolean | Menyemak sama ada rentetan itu sama ada "benar" atau "salah". |
IsCreditCard | Mengesahkan jika rentetan itu ialah nombor kad kredit yang sah. |
IsCurrency | Menyemak sama ada rentetan itu ialah format mata wang yang sah. |
IsDate | Mengesahkan jika rentetan ialah tarikh yang sah. |
IsDecimal | Memastikan rentetan mewakili nombor perpuluhan yang sah. |
IsEmail | Menyemak sama ada rentetan itu ialah format alamat e-mel yang sah. |
IsEmpty | Mengesahkan jika rentetan kosong. |
IsFQDN | Menyemak sama ada rentetan itu ialah nama domain yang layak sepenuhnya. |
IsFloat | Memastikan rentetan mewakili nombor titik terapung. |
IsHexColor | Mengesahkan jika rentetan ialah warna heks yang sah (mis., #FFFFFF). |
IsIP | Menyemak sama ada rentetan itu ialah alamat IP yang sah (IPv4 atau IPv6). |
IsISO8601 | Mengesahkan jika rentetan dalam format tarikh ISO8601. |
IsLength | Menyemak sama ada panjang rentetan berada dalam julat yang ditentukan. |
IsMimeType | Mengesahkan jika rentetan adalah jenis MIME yang sah. |
Adalah Telefon Bimbit | Menyemak sama ada rentetan itu ialah nombor telefon mudah alih yang sah untuk tempat yang ditentukan. |
IsMongoID | Mengesahkan jika rentetan itu ialah ID Objek MongoDB yang sah. |
IsNumeric | Memastikan rentetan hanya mengandungi aksara angka. |
IsPostalCode | Menyemak sama ada rentetan itu ialah poskod yang sah untuk tempat yang ditentukan. |
IsRFC3339 | Mengesahkan jika rentetan dalam format tarikh RFC3339. |
IsSlug | Menyemak sama ada rentetan itu mesra URL (hanya huruf, nombor dan sempang). |
IsStrongPassword | Memastikan rentetan memenuhi keperluan kekuatan kata laluan biasa. |
IsURL | Mengesahkan jika rentetan itu ialah URL. |
IsUUID | Menyemak sama ada rentetan itu ialah UUID yang sah (versi 1-5). |
IsUpperCase | Memastikan rentetan semuanya huruf besar. |
IsVAT | Menyemak sama ada rentetan itu ialah nombor VAT yang sah untuk negara tertentu. |
Perlawanan | Mengesahkan jika rentetan sepadan dengan ungkapan biasa yang ditentukan. |
Jadual ini harus meliputi kebanyakan pengesah yang kini tersedia di validatorgo. Pastikan anda merujuk kepada dokumentasi pakej untuk penggunaan yang lebih terperinci bagi setiap pengesah.
⚠ Awas
Apabila menggunakan pengesah yang memerlukan struct pilihan (sama ada penunjuk atau bukan penuding), sentiasa berikan nilai untuk semua medan struct secara eksplisit.
Tidak seperti dalam validator.js, apabila medan yang tiada ditetapkan secara automatik kepada lalai, Go menggunakan jenis yang ketat.
Ini bermakna nilai yang tiada akan lalai kepada palsu untuk boolean, 0 untuk jenis nombor, dsb.
Tidak menyatakan semua medan boleh membawa kepada tingkah laku yang tidak dijangka jika anda sudah biasa dengan versi JavaScript.
Contoh
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. |
Pembersih ini sering digunakan untuk memastikan konsistensi dan keselamatan data dengan menanggalkan atau mengubah suai aksara yang mungkin tidak diingini atau berbahaya.
Pastikan anda merujuk kepada dokumentasi rasmi validatorgo untuk pelaksanaan dan contoh khusus setiap sanitizer.
validatorgo ialah pilihan ideal jika anda memerlukan:
Dengan validatorgo, anda mendapat alat yang direka khusus untuk pengesahan rentetan, menyokong kedua-dua keperluan aplikasi kendiri dan web dalam Go.
Atas ialah kandungan terperinci Mempermudahkan Pengesahan Rentetan dalam Go: Memperkenalkan validatorgo. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!