Rumah >pembangunan bahagian belakang >Golang >Amalan pengesahan borang pembelajaran Golang untuk aplikasi web

Amalan pengesahan borang pembelajaran Golang untuk aplikasi web

王林
王林asal
2023-06-24 15:07:49959semak imbas

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:

  1. Tentukan struktur

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"表示这个字段是必须的。

  1. 定义路由

接下来,我们需要定义路由,并绑定相应的处理函数。在路由中使用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服务器处理。

  1. 表单验证

在进行表单验证之前,我们需要导入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)

    Tentukan laluan

    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.

      🎜Pengesahan borang🎜🎜🎜Sebelum melaksanakan pengesahan borang, kita perlu mengimport pakej 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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn