Go web表單驗證
阿新 • • 發佈:2018-05-06
選擇 all res true 服務器 過濾 信任 中文 else
開發Web的一個原則就是,不能信任用戶輸入的任何信息,所以驗證和過濾用戶的輸入信息就變得非常重要
必填字段
if len(r.Form["username"][0])==0{ //為空的處理 }
數字
getint,err:=strconv.Atoi(r.Form.Get("age")) if err!=nil{ //數字轉化出錯了,那麽可能就不是數字 } //接下來就可以判斷這個數字的大小範圍了 if getint >100 { //太大了 }
if m, _ := regexp.MatchString("^[0-9]+$", r.Form.Get("age")); !m { return false }
轉換數字和正則匹配
對於性能的話要避開正則,正則會有個匹配時間,多個匹配速度會慢,但服務器強勁則沒關系.
匹配中文
if m, _ := regexp.MatchString("^\\p{Han}+$", r.Form.Get("realname")); !m { return false }
匹配英文
if m, _ := regexp.MatchString("^[a-zA-Z]+$", r.Form.Get("engname")); !m { return false }
匹配郵箱
if m, _ := regexp.MatchString(`^([\w\.\_]{2,10})@(\w{1,}).([a-z]{2,4})$`, r.Form.Get("email")); !m { //匹配字母數字下劃線和點2到10個,加上@再匹配至少一個的字母數字下劃線,加上.匹配字母a-z(至少2到4位) fmt.Println("no") }else{ fmt.Println("yes") }
手機號碼
if m, _ := regexp.MatchString(`^(1[3|4|5|8][0-9]\d{4,8})$`, r.Form.Get("mobile")); !m { return false }
下拉菜單的判斷
slice:=[]string{"haha","ccc","bca"} //創建切片 v := r.Form.Get("fruit") for _, item := range slice { if item == v { return true } } return false
復選框選擇不同的
slice:=[]string{"football","basketball","tennis"} a:=Slice_diff(r.Form["interest"],slice) if a == nil{ return true } return false
身份證號
//驗證15位身份證,15位的是全部數字 if m, _ := regexp.MatchString(`^(\d{15})$`, r.Form.Get("usercard")); !m { return false } //驗證18位身份證,18位前17位為數字,最後一位是校驗位,可能為數字或字符X。 if m, _ := regexp.MatchString(`^(\d{17})([0-9]|X)$`, r.Form.Get("usercard")); !m { return false }
Go web表單驗證