Go语言通过net/http包统一处理HTTP表单:GET参数用r.ParseForm()后r.FormValue获取;POST标准表单同理;文件上传需r.ParseMultipartForm()或r.MultipartReader()。
Go语言通过net/http包原生支持HTTP请求处理,解析表单数据非常直接。关键在于区分GET和POST的参数来源:GET参数在URL查询字符串中,POST表单数据通常在请求体中(application/x-www-form-urlencoded或multipart/form-data),而Go统一用ParseForm()预处理后,都可通过Request.FormValue或Request.Form安全获取。
GET请求的参数附加在URL末尾(如/search?q=go&lang=zh),无需调用ParseForm()即可读取,但显式调用更稳妥,尤其当URL含编码字符时。
r.URL.Query().Get("key")可直接获取未解码的原始值(不推荐用于表单场景)r.ParseForm(),再用r.FormValue("key")——它自动解码URL编码,且对GET/POST一视同仁r.Form["key"]返回[]string,注意判空HTML表单默认以application/x-www-form-urlencoded格式提交,Go会自动识别并解析其内容,但必须先调用r.ParseForm(),否则Form字段为空。
r.ParseForm()应在读取r.PostForm或r.FormValue前调用一次,多次调用无副作用r.FormValue("username")返回第一个匹配值(适合单值字段),内部已处理空值和编码r.PostFormValue("password")等价于r.FormValue,但只读取POST部分(对GET请求无效)multipart/form-data
当表单设置enctype="multipart/form-data"时,ParseForm()无法解析文件字段,必须用ParseMultipartForm()或直接调用r.MultipartReader()。
r.ParseMultipartForm(32 (如32MB内存限制)后,普通字段仍可用r.FormValue()获取
r.FormFile("avatar")获取*multipart.FileHeader,再用header.Open()读取内容http.ErrNotMultipart表示非multipart请求,http.ErrMissingFile表示字段不存在实际开发中不能假设参数一定存在或格式正确,需主动校验:
strings.TrimSpace(r.FormValue("email"))去除首尾空格再验证strconv.Atoi转换,并检查错误,避免panic
gorilla/csrf等库辅助