开发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 }
原文地址:https://www.cnblogs.com/esiarp/p/8996973.html
时间: 2024-11-08 03:57:14