关于数据验证
在 web 应用的录入界面,数据验证是一项重要的实现功能,数据验证是指确认 web 控件输入或选择的数据,是否满足数据表数据约束,是否满足应用程序所需要数据约束规则。建立数据库约束可以满足数据验证的应用,但在实际的应用中,我们建议还是在更新信息到数据库前,在应用中执行数据验证,这样可减少错误录入,减少应用程序与数据库之间频繁通信造成的服务器压力。通过有效的数据验证,可以确认写入数据表中的数据是有效且符合预期的。本文我们将介绍如何通过c# 后端及javascript 前端对 web 控件进行数据输入有效性的验证。
范例运行环境
操作系统: windows server 2019 datacenter
.net版本: .netframework4.7.1 或以上
开发工具:vs2019 c#
验证设计
通过对 web 服务器控件捆绑自定义属性 checkschema="" 和 cname="",将自定义的校验类型和中文提示进行赋值,即可完成验证的设置,可实现的校验类型如下图所示:

多个数据校验类型请用“|”进行分隔,如下设计举例:
示例 1:不能为空且必须为日期型数据
<asp:textbox id="x1" checkschema="notnull|date" cname="出生日期" runat="server" />
示例 2:必须为身份证号
<asp:textbox id="x1" checkschema="idcard" runat="server" />
示例3:必须输入4位的一个整型数
<asp:textbox id="x1" checkschema="mustlen4|int" runat="server" />
javascript 方法
设计
在前端客户端,使用 javascript 方法 simplecheck 进行数据验证,验证通过反回 true,否则为 false,其参数说明如下表:
| 序号 | 参数名 | 类型 | 说明 |
|---|---|---|---|
| 1 | chkobj | dom元素对象 | 如传递一个 input type="text" 的对象 |
| 2 | _chkvalue | 字符串值 | dom元素对象的值,如 value 属性值 |
| 3 | allowalert | 布尔值 | 当验证错误时是否允许弹出alert提示框,true为允许 |
| 4 | etip | 字符串值 | 附加的前缀提示信息,后缀为方法提供的定义的错误提示信息 |
实现
simplecheck 方法完整代码如下:
function simplecheck(chkobj, _chkvalue, allowalert,etip) {
check_result = true; check_errid = ''; check_errmsg = '';var _checkschema = chkobj.getattribute('checkschema');var _cname = chkobj.getattribute('cname');
if (_checkschema.indexof('ctrim') != -1) { _chkvalue = ctrim(_chkvalue); } var _objlength = _chkvalue.length; if (_checkschema.indexof('abslen') != -1) { _objlength = positionlen(_chkvalue); }
var _schemalist = _checkschema.split('|'); var _reqeustnotnull = false;
for (var k = 0; k < _schemalist.length; k++) { if (_schemalist[k].tolowercase() == 'notnull') { _reqeustnotnull = true; } }
if ((!_reqeustnotnull) && (_chkvalue == '')) { return check_result; }
for (var j = 0; j < _schemalist.length; j++) {
var curschema = _schemalist[j].tolowercase(); check_errid = curschema; var curerrmsg = ''; switch (true) { case curschema == 'notnull': check_result = isnotnull(_chkvalue); curerrmsg = _cname + '需要填写内容!'; break; case curschema == 'number': check_result = isnumber(_chkvalue); curerrmsg = _cname + ' 输入的数值不合理,请核对!'; break; case curschema == 'bnumber': check_result = isbnumber(_chkvalue); curerrmsg = _cname + ' 输入的数值应为>=0的正数,请核对!'; break; case curschema == 'snumber': check_result = issnumber(_chkvalue); curerrmsg = _cname + ' 输入的数值应为<0的负数,请核对!'; break; case curschema == 'date': check_result = isdate(_chkvalue, _cname); check_errid = 'date'; check_errmsg = (check_result ? '' : _cname + ' 输入的日期不合理,请核对!'); curerrmsg = ''; break; case curschema.indexof('minlen') != -1: var _slen = parseint(curschema.substr('minlen'.length, curschema.length - 'minlen'.length), 10); if (isnan(_slen)) { check_result = false; curerrmsg = _cname + ' 输入的最小位数参数不合理,请与软件供应商联系!'; } else { check_result = (_objlength < _slen ? false : true); curerrmsg = _cname + ' 的内容要求最小输入' + _slen + '位,请核对!'; } break; case curschema.indexof('maxlen') != -1: var _slen = parseint(curschema.substr('maxlen'.length, curschema.length - 'maxlen'.length), 10); if (isnan(_slen)) { check_result = false; curerrmsg = _cname + ' 输入的最大位数参数不合理,请与软件供应商联系!'; } else { check_result = (_objlength > _slen ? false : true); curerrmsg = _cname + ' 最大允许输入' + _slen + '位,请核对!'; } break; case curschema.indexof('mustlen') != -1: var _slen = parseint(curschema.substr('mustlen'.length, curschema.length - 'mustlen'.length), 10); if (isnan(_slen)) { check_result = false; curerrmsg = _cname + ' 输入的限制位数参数不合理,请与软件供应商联系!'; } else { check_result = (_objlength != _slen ? false : true); curerrmsg = _cname + ' 的内容输入长度只能是' + _slen + '位,请核对!'; } break; case curschema == 'time': check_result = validregs(_chkvalue, /^\d{1,2}:\d{1,2}:\d{1,2}$/); curerrmsg = _cname + ' 输入的时间不合理,请核对。'; break; case curschema == 'alpha': check_result = isalpha(_chkvalue); curerrmsg = _cname + ' 只能输入的数字、字母和下划线,请核对。'; break; case curschema == 'mail': check_result = validregs(_chkvalue, /^([a-za-z0-9._-])+@([a-za-z0-9_-])+(\.[a-za-z0-9_-])+/); curerrmsg = _cname + ' 输入的邮件地址不合理,请核对。'; break; case curschema == 'phone': check_result = validregs(_chkvalue, /([a-za-z0-9\.-\u4e00-\u9fa5]{8,})$/); curerrmsg = _cname + ' 输入的电话号码不合理,请核对。'; break; case curschema == 'mobile': check_result = validregs(_chkvalue, /^1(3[0-9]|5[012356789]|8[056789])\d{8}$/); curerrmsg = _cname + ' 输入的手机号码不合理,请核对。'; break; case curschema == 'money': check_result = validregs(_chkvalue, /^\d+(\.\d+)?$/); curerrmsg = _cname + ' 输入的内容不符合货币类型的要求,请核对。'; break; case curschema == 'zip': check_result = validregs(_chkvalue, /^[1-9]\d{5}$/); curerrmsg = _cname + ' 输入的邮政编码不合理,请核对。'; break; case curschema == 'int': check_result = validregs(_chkvalue, /^[-\+]?\d+$/); curerrmsg = _cname + ' 需要输入一个整数,请核对。'; break; case curschema == 'en': check_result = validregs(_chkvalue, /^[a-za-z]+$/); curerrmsg = _cname + ' 只能输入英文大小写字母,请核对。'; break; case curschema == 'cn': check_result = validregs(_chkvalue, /^[\u0391-\uffe5]+$/); curerrmsg = _cname + ' 只能输入中文,请核对。'; break; case curschema == 'url': check_result = validregs(_chkvalue, /([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?/); curerrmsg = _cname + ' 输入的网址不合理,请核对。'; break; case curschema == 'idcard18': rv_result = checkidcard(_chkvalue); check_result = (rv_result == '' ? true : false); curerrmsg = _cname + rv_result; break; case curschema == 'idcard15': rv_result = checkidcard(_chkvalue); check_result = (rv_result == '' ? true : false); curerrmsg = _cname + rv_result; break; case curschema == 'idcard': rv_result = checkidcard(_chkvalue); check_result = (rv_result == '' ? true : false); curerrmsg = _cname + rv_result; break; } if (!check_result) {
if (curerrmsg != '') { check_errmsg = etip + curerrmsg; } if ((curerrmsg != '') && (allowalert)) { alert(etip + curerrmsg); return check_result; }
}
}
return check_result;
}验证函数完整代码如下:
function checkidcard(idcard) {
var _idcard = idcard; var errors = new array('', '身份证号码位数不对!', '身份证号码出生日期超出范围或含有非法字符!', '身份证号码校验错误!', '身份证地区非法!', '');
if (_idcard == '') { return errors[5]; }
var area = { 11: '北京', 12: '天津', 13: '河北', 14: '山西', 15: '内蒙古', 21: '辽宁', 22: '吉林', 23: '黑龙江', 31: '上海', 32: '江苏', 33: '浙江', 34: '安徽', 35: '福建', 36: '江西', 37: '山东', 41: '河南', 42: '湖北', 43: '湖南', 44: '广东', 45: '广西', 46: '海南', 50: '重庆', 51: '四川', 52: '贵州', 53: '云南', 54: '西藏', 61: '陕西', 62: '甘肃', 63: '青海', 64: '宁夏', 65: '新疆', 71: '台湾', 81: '香港', 82: '澳门', 91: '国外' }
var _idcard, y, jym; var s, m; var idcard_array = new array(); idcard_array = _idcard.split('');
if (area[parseint(_idcard.substr(0, 2))] == null) { return errors[4]; }
switch (_idcard.length) {
case 15: if ((parseint(_idcard.substr(6, 2)) + 1900) % 4 == 0 || ((parseint(_idcard.substr(6, 2)) + 1900) % 100 == 0 && (parseint(_idcard.substr(6, 2)) + 1900) % 4 == 0)) {
ereg = /^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;
} else {
ereg = /^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;
}
if (ereg.test(_idcard)) {
var is = 0; var iw = new array; iw[0] = 7; iw[1] = 9; iw[2] = 10; iw[3] = 5; iw[4] = 8; iw[5] = 4; iw[6] = 2; iw[7] = 1; iw[8] = 6; iw[9] = 3; iw[10] = 7; iw[11] = 9; iw[12] = 10; iw[13] = 5; iw[14] = 8; iw[15] = 4; iw[16] = 2;
var lastcode = '10x98765432'; var peridnew; peridnew = _idcard.substr(0, 6); peridnew += '19'; peridnew += _idcard.substr(6, 9);
for (var i = 0; i < 17; i++) { is += parseint(peridnew.substr(i, 1)) * iw[i]; }
var iy = is % 11; peridnew += lastcode.substr(iy, 1);
return errors[0];
} else {
return errors[2];
}
break;
case 18: if (parseint(_idcard.substr(6, 4)) % 4 == 0 || (parseint(_idcard.substr(6, 4)) % 100 == 0 && parseint(_idcard.substr(6, 4)) % 4 == 0)) {
ereg = _idcard.substr(6, 2) == '19' ? /^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9xx]$/ : /^[1-9][0-9]{5}20[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}[0-9xx]$/;
} else {
ereg = _idcard.substr(6, 2) == '19' ? /^[1-9][0-9]{5}19[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9xx]$/ : /^[1-9][0-9]{5}20[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}[0-9xx]$/;
}
if (ereg.test(_idcard)) {
s = (parseint(idcard_array[0]) + parseint(idcard_array[10])) * 7 + (parseint(idcard_array[1]) + parseint(idcard_array[11])) * 9 + (parseint(idcard_array[2]) + parseint(idcard_array[12])) * 10 + (parseint(idcard_array[3]) + parseint(idcard_array[13])) * 5 + (parseint(idcard_array[4]) + parseint(idcard_array[14])) * 8 + (parseint(idcard_array[5]) + parseint(idcard_array[15])) * 4 + (parseint(idcard_array[6]) + parseint(idcard_array[16])) * 2 + parseint(idcard_array[7]) * 1 + parseint(idcard_array[8]) * 6 + parseint(idcard_array[9]) * 3;
y = s % 11; m = 'f'; jym = '10x98765432'; m = jym.substr(y, 1); if (m == idcard_array[17]) return errors[0]; else { return errors[3]; }
} else { return errors[2]; } break; default: return errors[1]; break;
}
}
function getid(id) { alert(checkidcard(id)) }
function per18to15(peridsrc) { rstr = ''; for (var i = 0; i < 17; i++) { if ((i == 6) || (i == 7)) { continue; } rstr += peridsrc.charat(i); } return rstr; }
function per15to18(peridsrc) {
var is = 0; var iw = new array;
iw[0] = 7; iw[1] = 9; iw[2] = 10; iw[3] = 5; iw[4] = 8; iw[5] = 4; iw[6] = 2; iw[7] = 1; iw[8] = 6; iw[9] = 3; iw[10] = 7; iw[11] = 9; iw[12] = 10; iw[13] = 5; iw[14] = 8; iw[15] = 4; iw[16] = 2;
var lastcode = '10x98765432'; var peridnew; peridnew = peridsrc.substr(0, 6); peridnew += '19'; peridnew += peridsrc.substr(6, 9);
for (var i = 0; i < 17; i++) { is += parseint(peridnew.substr(i, 1)) * iw[i]; }
var iy = is % 11; peridnew += lastcode.substr(iy, 1); return peridnew;
}
var acity = { 11: '北京', 12: '天津', 13: '河北', 14: '山西', 15: '内蒙古', 21: '辽宁', 22: '吉林', 23: '黑龙江', 31: '上海', 32: '江苏', 33: '浙江', 34: '安徽', 35: '福建', 36: '江西', 37: '山东', 41: '河南', 42: '湖北', 43: '湖南', 44: '广东', 45: '广西', 46: '海南', 50: '重庆', 51: '四川', 52: '贵州', 53: '云南', 54: '西藏', 61: '陕西', 62: '甘肃', 63: '青海', 64: '宁夏', 65: '新疆', 71: '台湾', 81: '香港', 82: '澳门', 91: '国外' }
function cidinfo(sid) {
var isum = 0; var info = '';
if (!/^\d{17}(\d|x)$/i.test(sid))
return false; sid = sid.replace(/x$/i, 'a');
if (acity[parseint(sid.substr(0, 2))] == null) return 'error:非法地区'; sbirthday = sid.substr(6, 4) + '-' + number(sid.substr(10, 2)) + '-' + number(sid.substr(12, 2));
var d = new date(sbirthday.replace(/-/g, '/'))
if (sbirthday != (d.getfullyear() + '-' + (d.getmonth() + 1) + '-' + d.getdate()))
return 'error:非法生日';
for (var i = 17; i >= 0; i--) isum += (math.pow(2, i) % 11) * parseint(sid.charat(17 - i), 11)
if (isum % 11 != 1) return 'error:非法证号';
return acity[parseint(sid.substr(0, 2))] + ',' + sbirthday + ',' + (sid.substr(16, 1) % 2 ? '男' : '女')
}
function positionlen(s){var i,str1,str2,str3,nlen; str1 =s;nlen = 0;for(i=1;i<=str1.length;i++){str2=str1.substring(i-1,i);str3=escape(str2);if(str3.length>3){ nlen = nlen + 2;}else{nlen = nlen + 1;} }
return nlen;}
function isnotnull(str){return (str==''?false:true);}
function isnumber(str){if(str==''){return true;}return (isnan(str)?false:true);}
function isnumber(str){if(str==''){return true;}return (isnan(str)?false:true);}
function isbnumber(str){if(str==''){return true;}return (!isnan(str)?parseint(str,10)>=0?true:false:false);}
function issnumber(str){if(str==''){return true;}return (!isnan(str)?parseint(str,10)<0?true:false:false);}
function isalpha(_str){return (_str.replace(/\w/g,'').length == 0);}
function isan(_str){var reg = /^(([a-z]+[0-9]+)|([0-9]+[a-z]+))[a-z0-9]*$/i;return reg.test(_str);}
function validregs(_value,_regs){return _regs.test(_value); }
function isvisibled(obj){ if( (obj.style.display=='none')||( (obj.offsetheight==0)&&(obj.offsetwidth==0) ) ) return false; if(obj.currentstyle){if(obj.currentstyle['display']=='none') return false;} return true;}
function isfocused(obj){ if( (obj.disabled==false)&&(isvisibled(obj)) ) return true; return false;}
function isdate(str,cname,notip){if(str==''){return true;}
str=str.replace(/\//g,'-');
dt=str.split(' ');if(dt.length>2){if(!notip) alert(cname+'日期输入不正确!可能包括非法的日期组成部分。');return false; } dt1=dt[0].split('-');if(dt1.length!=3){if(!notip) alert(cname+'日期输入不正确!日期部分应为yyyy-mm-dd。');return false;}dt1n=(dt1[0]+dt1[1]+dt1[2]).split('');for(var i=0;i<dt1.length;i++){if((isnan(dt1[i])||(ctrim(dt1[i])==''))){if(!notip) alert(cname+'字符:'+dt1[i]+',年月日部分必须输入数字!'); return false;} }_year=parseint(dt1[0],10); _month=parseint(dt1[1],10); _day=parseint(dt1[2],10);if((_year<1000)||(_year>9999)||(_month<1)||(_month>12)||(_day<1)||(_day>31)){if(!notip) alert(cname+'年月日部分输入的数字不合理,请核对!');return false; }v_date31=new array;v_date31[0]=4;v_date31[1]=6;v_date31[2]=9;v_date31[3]=11;if((getarrayindex(v_date31,_month)!=-1)&&(_day>30)){if(!notip) alert(cname+'月份:'+_month+',天数输入范围不合理!'); return false;}if(_month==2){ if(((_year%4==0)&&(_year%100!=0))||(_year%400==0)){ if(_day>29){if(!notip) alert(cname+'月份:'+_month+',天数输入范围不合理!');return false; }}else{ if(_day>28){if(!notip) alert(cname+'月份:'+_month+',天数输入范围不合理!');return false; }} } return true; }
function getarrayindex(xarray,find){_rs=-1;for(var j=0;j<xarray.length;j++){if(xarray[j]==find){_rs=j; break; }} return _rs; }
function ctrim(ename){ if(ename==undefined) return ''; return (ename.replace(/(^\s*)|(\s*$)/g, '')).replace(/^[\s \t]+|[\s \t]+$/, '');}调用示例
假设对 id 为 x1 的输入框元素进行身份证号验证,代码如下:
if(simplecheck(document.getelementbyid('x1'),document.getelementbyid('x1').value, true,"您输入的")==false){
return false;
}c# 方法
设计
客户端检验一般属于弱检验,为保证数据的安全合法性,还需要在后端服务端进行二次检验,使用 c# 方法 checkschemaservervalid 进行数据验证,验证通过返回空字符串信息,否则返回错误提示信息,其参数说明如下表:
| 序号 | 参数名 | 类型 | 说明 |
|---|---|---|---|
| 1 | value | string | 要校验的数据值 |
| 2 | _checkschema | string | 传递校验方案,即传递 web 控件的自定义 checkschema 属性值 |
| 3 | _cname | string | 中文说明,即传递 web 控件的自定义 cname 属性值 |
实现
simplecheck 方法完整代码如下:
public string checkschemaservervalid(string value,string _checkschema,string _cname)
{
servervaliderrortype = "";
string check_errmsg = "";
_checkschema=_checkschema.tolower();
if (_checkschema.indexof("ctrim") != -1) { value = value.trim(); }
int _objlength = value.length;
if (_checkschema.indexof("notnull") == -1 && _objlength == 0) { return check_errmsg; }
string[] _schemalist = _checkschema.split('|');
for (var j = 0; j < _schemalist.length; j++) {
string curschema = _schemalist[j];
string curerrmsg="";
if(curschema=="notnull") {
curerrmsg = isnotnull(value)?"":_cname + "需要填写内容!";
}else if(curschema=="number") {
curerrmsg =isnumeric(value)?"":_cname + " 输入的数值不合理,请核对!";
}else if(curschema=="bnumber") {
curerrmsg = isbnumeric(value)?"":_cname +" 输入的数值应为>=0的正数,请核对!";
}else if(curschema=="snumber") {
curerrmsg = issnumeric(value)?"":_cname + " 输入的数值应为<0的负数,请核对!";
}else if(curschema=="date") {
curerrmsg = isdate(value)?"": _cname + " 输入的日期不合理,请核对!";
}else if(curschema.indexof("minlen")!=-1) {
int _slen =int.parse(curschema.substring("minlen".length, curschema.length - "minlen".length));
curerrmsg= value.length>= _slen ? "": _cname + " 的内容要求最小输入" + _slen.tostring() + "位,请核对!";
}else if(curschema.indexof("maxlen")!=-1) {
int _mlen =int.parse(curschema.substring("maxlen".length, curschema.length - "maxlen".length));
curerrmsg= value.length<= _mlen ? "": _cname + " 的内容要求最大输入" + _mlen.tostring() + "位,请核对!";
}else if(curschema.indexof("mustlen")!=-1) {
int _mlen =int.parse(curschema.substring("mustlen".length, curschema.length - "mustlen".length));
curerrmsg= value.length== _mlen ? "": _cname + " 的内容输入长度只能是" + _mlen.tostring() + "位,请核对!";
}else if(curschema=="time"){
curerrmsg = isdate(value)?"": _cname + " 输入的时间不合理,请核对!";
}else if(curschema=="alpha"){
curerrmsg =isalpha(value)?"": _cname + " 只能输入的数字、字母和下划线,请核对。";
}else if(curschema=="mail"){
curerrmsg =isemail(value)?"": _cname + " 输入的邮件地址不合理,请核对。";
}else if(curschema=="phone"){
curerrmsg =isphone(value)?"": _cname + " 输入的电话号码不合理,请核对。";
}else if(curschema=="mobile"){
curerrmsg =ismobilephone(value)?"":_cname + " 输入的手机号码不合理,请核对。";
}else if(curschema=="money"){
curerrmsg =isnumeric(value)?"": _cname + " 输入的内容不符合货币类型的要求,请核对。";
}else if(curschema=="zip"){
curerrmsg =iszip(value)?"": _cname + " 输入的邮政编码不合理,请核对。";
}else if(curschema=="int"){
curerrmsg =isint(value)?"": _cname + " 需要输入一个整数,请核对。";
}else if(curschema=="en"){
curerrmsg =isenglish(value)?"":_cname + " 只能输入英文大小写字母,请核对。";
}else if(curschema=="cn"){
curerrmsg =ischinesech(value)?"": _cname + " 只能输入中文,请核对。";
}else if(curschema=="url"){
curerrmsg =isurl(value)?"":_cname + " 输入的网址不合理,请核对。";
}else if(curschema=="idcard"){
curerrmsg =checkidcard(value)?"": _cname + " 请输入合理的15或18位号码。";
}else if(curschema=="idcard18"){
curerrmsg =checkidcard18(value)?"": _cname + " 请输入合理的18位号码。";
}else if(curschema=="idcard15"){
curerrmsg =checkidcard(value)?"": _cname + " 请输入合理的15位号码。";
}else if (curschema == "an"){
curerrmsg = isan(value) ? "" : _cname + " 必须包含数字和字母。";
}
check_errmsg = curerrmsg;
if(check_errmsg!=""){
servervaliderrortype = curschema;
break;
}
}
return check_errmsg;
}c#验证函数完整代码如下:
public bool checkidcard(string idnumber)
{
if (idnumber.length == 18)
{
bool check = checkidcard18(idnumber);
return check;
}
else if (idnumber.length == 15)
{
bool check = checkidcard15(idnumber);
return check;
}
else
{
return false;
}
}
/// <summary>
/// 18位身份证号码验证
/// </summary>
public bool checkidcard18(string idnumber)
{
if (idnumber.length != 18)
{
return false;
}
long n = 0;
if (long.tryparse(idnumber.remove(17), out n) == false
|| n < math.pow(10, 16) || long.tryparse(idnumber.replace('x', '0').replace('x', '0'), out n) == false)
{
return false;//数字验证
}
string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91";
if (address.indexof(idnumber.remove(2)) == -1)
{
return false;//省份验证
}
string birth = idnumber.substring(6, 8).insert(6, "-").insert(4, "-");
datetime time = new datetime();
if (datetime.tryparse(birth, out time) == false)
{
return false;//生日验证
}
string[] arrvarifycode = ("1,0,x,9,8,7,6,5,4,3,2").split(',');
string[] wi = ("7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2").split(',');
char[] ai = idnumber.remove(17).tochararray();
int sum = 0;
for (int i = 0; i < 17; i++)
{
sum += int.parse(wi[i]) * int.parse(ai[i].tostring());
}
int y = -1;
math.divrem(sum, 11, out y);
if (arrvarifycode[y] != idnumber.substring(17, 1).tolower())
{
return false;//校验码验证
}
return true;//符合gb11643-1999标准
}
public bool checkidcard15(string idnumber)
{
if (idnumber.length != 15)
{
return false;
}
long n = 0;
if (long.tryparse(idnumber, out n) == false || n < math.pow(10, 14))
{
return false;//数字验证
}
string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91";
if (address.indexof(idnumber.remove(2)) == -1)
{
return false;//省份验证
}
string birth = idnumber.substring(6, 6).insert(4, "-").insert(2, "-");
datetime time = new datetime();
if (datetime.tryparse(birth, out time) == false)
{
return false;//生日验证
}
return true;
}
public bool isnotnull(string value){
return value.length==0?false:true;
}
public bool isnumeric(string value)
{
return regex.ismatch(value, @"^[+-]?\d*[.]?\d*$");
}
public bool isbnumeric(string value)
{
if(regex.ismatch(value, @"^[+-]?\d*[.]?\d*$")==true){
return float.parse(value)>=0?true:false;
}
return false;
}
public bool issnumeric(string value)
{
if(regex.ismatch(value, @"^[+-]?\d*[.]?\d*$")==true){
return float.parse(value)<0?true:false;
}
return false;
}
public bool isint(string value)
{
return regex.ismatch(value, @"^[+-]?\d*$");
}
public bool isunsign(string value)
{
return regex.ismatch(value, @"^\d*[.]?\d*$");
}
public bool istel(string strinput)
{
return regex.ismatch(strinput, @"\d{3}-\d{8}|\d{4}-\d{7}");
}
public bool isdate(string value)
{
try
{
datetime.parse(value);
return true;
}
catch
{
return false;
}
}
public bool isalpha(string value){
return regex.ismatch(value, @"^\w+$");
}
public bool isemail(string value){
return regex.ismatch(value,@"^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-za-z]{2,4}|[0-9]{1,3})(\]?)$");
}
/// 匹配3位或4位区号的电话号码,其中区号可以用小括号括起 /// 也可以不用,区号与本地号间可以用连字号或空格间隔, /// 也可以没有间隔
public bool isphone(string input)
{
string pattern = "^\\(0\\d{2}\\)[- ]?\\d{8}$|^0\\d{2}[- ]?\\d{8}$|^\\(0\\d{3}\\)[- ]?\\d{7}$|^0\\d{3}[- ]?\\d{7}$";
regex regex = new regex(pattern);
return regex.ismatch(input);
}
public bool ismobilephone(string input)
{
regex regex = new regex("^13\\d{9}$");
return regex.ismatch(input);
}
public bool iszip(string value){
return regex.ismatch(value, @"^\d{6}$");
}
public bool isenglish(string input)
{
regex regex = new regex("^[a-za-z]+$");
return regex.ismatch(input);
}
public bool ischinesech(string input)
{
regex regex = new regex("^[\u4e00-\u9fa5]+$");
return regex.ismatch(input);
}
public bool isurl(string input)
{
string pattern = @"^[a-za-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\s*)?$";
regex regex = new regex(pattern);
return regex.ismatch(input);
}
public bool checkidcard(string idnumber)
{
if (idnumber.length == 18)
{
bool check = checkidcard18(idnumber);
return check;
}
else if (idnumber.length == 15)
{
bool check = checkidcard15(idnumber);
return check;
}
else
{
return false;
}
}
/// <summary>
/// 18位身份证号码验证
/// </summary>
public bool checkidcard18(string idnumber)
{
if (idnumber.length != 18)
{
return false;
}
long n = 0;
if (long.tryparse(idnumber.remove(17), out n) == false
|| n < math.pow(10, 16) || long.tryparse(idnumber.replace('x', '0').replace('x', '0'), out n) == false)
{
return false;//数字验证
}
string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91";
if (address.indexof(idnumber.remove(2)) == -1)
{
return false;//省份验证
}
string birth = idnumber.substring(6, 8).insert(6, "-").insert(4, "-");
datetime time = new datetime();
if (datetime.tryparse(birth, out time) == false)
{
return false;//生日验证
}
string[] arrvarifycode = ("1,0,x,9,8,7,6,5,4,3,2").split(',');
string[] wi = ("7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2").split(',');
char[] ai = idnumber.remove(17).tochararray();
int sum = 0;
for (int i = 0; i < 17; i++)
{
sum += int.parse(wi[i]) * int.parse(ai[i].tostring());
}
int y = -1;
math.divrem(sum, 11, out y);
if (arrvarifycode[y] != idnumber.substring(17, 1).tolower())
{
return false;//校验码验证
}
return true;//符合gb11643-1999标准
}
public bool checkidcard15(string idnumber)
{
if (idnumber.length != 15)
{
return false;
}
long n = 0;
if (long.tryparse(idnumber, out n) == false || n < math.pow(10, 14))
{
return false;//数字验证
}
string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91";
if (address.indexof(idnumber.remove(2)) == -1)
{
return false;//省份验证
}
string birth = idnumber.substring(6, 6).insert(4, "-").insert(2, "-");
datetime time = new datetime();
if (datetime.tryparse(birth, out time) == false)
{
return false;//生日验证
}
return true;
}
调用示例
假设对 id 为 x1 的输入框元素进行身份证号验证,代码如下:
string rv=checkschemaservervalid(x1.text,x1.attributes["checkschema"],"身份证号");
if(rv!=""){
response.write(rv);
}else{
response.write("校验通过");
}小结
本方法提供了一些基础的且实用的验证类型方法,我们在实际的应用中,可以通过扩展自定义 checkschema 属性中提供的验证类型以满足自己的应用。
如何遍历界面需要校验输入字段,可通过 javascript 进行控制,这里不再赘述。
以上就是c#结合javascript对web控件进行数据输入验证的实现方法的详细内容,更多关于c# javascript web数据验证的资料请关注代码网其它相关文章!
发表评论