Dalam pembangunan web, pengesahan borang adalah bahagian yang sangat kritikal. Pengesahan borang boleh melindungi keselamatan data dengan berkesan dan mencegah serangan dan operasi berniat jahat oleh pengguna yang menyalahi undang-undang. Di Golang, teknologi pengesahan borang juga digunakan secara meluas terutamanya dalam aplikasi web. Artikel ini akan memperkenalkan amalan pengesahan borang untuk aplikasi web di Golang.
1. Prinsip asas pengesahan borang
Dalam aplikasi web, prinsip asas pengesahan borang adalah untuk menyemak dan mengesahkan data sebelum menyerahkan data pada halaman web. Data ini mungkin nama pengguna, kata laluan, e-mel, nombor telefon, dsb. yang dimasukkan oleh pengguna, atau medan lain yang perlu disahkan dan diproses. Sebelum mengesahkan data ini, anda perlu menentukan jenis data dan peraturan pengesahan. Ungkapan biasa biasanya digunakan untuk pengesahan data. Jika pengesahan data lulus, data boleh diserahkan kepada pelayan web untuk diproses. Jika tidak, pengguna perlu digesa untuk memasukkan data yang betul dan mengisi semula borang.
2. Cara melaksanakan pengesahan borang di Golang
Di Golang, terdapat banyak cara untuk melaksanakan pengesahan borang. Berikut ialah kaedah pelaksanaan asas:
Pertama, kita perlu menentukan struktur untuk menyimpan data yang diserahkan dalam borang. Medan dalam struktur perlu menentukan jenis dan peraturan pengesahan yang sepadan.
type User struct { Name string `form:"name" binding:"required"` Password string `form:"password" binding:"required,min=6,max=20"` Email string `form:"email" binding:"required,email"` Phone string `form:"phone" binding:"required,phone"` }
Dalam kod di atas, kami mentakrifkan struktur Pengguna, yang mempunyai empat medan yang mewakili nama pengguna, kata laluan, e-mel dan nombor telefon. Dalam bidang struktur, kami menggunakan teknologi tag Golang. Contohnya, form: "name"
bermaksud atribut nama medan ini dalam borang web ialah nama dan binding: "required"
bermaksud medan ini diperlukan. form:"name"
表示这个字段在Web表单中的name属性是name,binding:"required"
表示这个字段是必须的。
接下来,我们需要定义路由,并绑定相应的处理函数。在路由中使用POST方法来接收表单提交的数据。
router.POST("/register", func(c *gin.Context) { var user User if err := c.ShouldBind(&user); err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return } // 数据验证通过,提交到Web服务器处理 c.JSON(http.StatusOK, gin.H{"success": "注册成功"}) })
上述代码中,我们使用c.ShouldBind(&user)
来将Web表单中提交的数据绑定到User结构体中。如果绑定失败,会返回相应的错误信息。如果绑定成功,说明数据验证通过,可以将数据提交到Web服务器处理。
在进行表单验证之前,我们需要导入Golang中的github.com/go-playground/validator/v10
包。该包是验证表单数据的主要工具。
import ( "net/http" "github.com/gin-gonic/gin" "github.com/go-playground/validator/v10" ) // 自定义验证函数 var validate *validator.Validate func init() { validate = validator.New() validate.RegisterValidation("phone", validatePhone) } func validatePhone(fl validator.FieldLevel) bool { phone := fl.Field().String() if phone == "" { return true } if !regexp.MustCompile(`^1[3456789]d{9}$`).MatchString(phone) { return false } return true }
在上述代码中,我们首先定义了一个全局的validate
对象,然后定义了一个名为validatePhone的自定义验证函数。该函数会检查电话号码是否符合规则。
最后,在路由处理函数中,我们可以使用validate.Struct(user)
Seterusnya, kita perlu menentukan laluan dan mengikat fungsi pemprosesan yang sepadan. Gunakan kaedah POST dalam laluan untuk menerima data yang dihantar oleh borang.
if err := validate.Struct(user); err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return }
Dalam kod di atas, kami menggunakan c.ShouldBind(&user)
untuk mengikat data yang diserahkan dalam borang web kepada struktur Pengguna. Jika pengikatan gagal, mesej ralat yang sepadan akan dikembalikan. Jika pengikatan berjaya, ini bermakna pengesahan data telah lulus dan data boleh diserahkan kepada pelayan web untuk diproses.
github.com/go-playground/validator/v10
di Golang. Pakej ini ialah alat utama untuk mengesahkan data borang. 🎜rrreee🎜Dalam kod di atas, kami mula-mula mentakrifkan objek validas
global, dan kemudian mentakrifkan fungsi pengesahan tersuai bernama validatePhone. Fungsi ini menyemak sama ada nombor telefon mematuhi peraturan. 🎜🎜Akhir sekali, dalam fungsi pemprosesan penghalaan, kita boleh menggunakan validate.Struct(user)
untuk mengesahkan data dalam struktur Pengguna. Contohnya: 🎜rrreee🎜Jika pengesahan gagal, mesej ralat yang sepadan akan dikembalikan. Jika pengesahan berjaya, data boleh diserahkan kepada pelayan web untuk diproses. 🎜🎜3. Ringkasan🎜🎜Artikel ini memperkenalkan amalan pengesahan borang aplikasi web di Golang. Di Golang, pengesahan bentuk data boleh dilaksanakan dengan mudah menggunakan teknologi seperti perpustakaan struktur, penghalaan dan pengesahan. Dalam pembangunan sebenar, kita perlu menentukan struktur, peraturan pengesahan dan penghalaan mengikut keperluan sebenar pengguna. Saya harap artikel ini dapat memberi sedikit rujukan untuk pemula. 🎜Atas ialah kandungan terperinci Amalan pengesahan borang pembelajaran Golang untuk aplikasi web. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!