1. 程式人生 > >Go web表單驗證

Go web表單驗證

選擇 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表單驗證