C#結(jié)合JavaScript對(duì)Web控件進(jìn)行數(shù)據(jù)輸入驗(yàn)證的實(shí)現(xiàn)方法
關(guān)于數(shù)據(jù)驗(yàn)證
在 Web 應(yīng)用的錄入界面,數(shù)據(jù)驗(yàn)證是一項(xiàng)重要的實(shí)現(xiàn)功能,數(shù)據(jù)驗(yàn)證是指確認(rèn) Web 控件輸入或選擇的數(shù)據(jù),是否滿足數(shù)據(jù)表數(shù)據(jù)約束,是否滿足應(yīng)用程序所需要數(shù)據(jù)約束規(guī)則。建立數(shù)據(jù)庫約束可以滿足數(shù)據(jù)驗(yàn)證的應(yīng)用,但在實(shí)際的應(yīng)用中,我們建議還是在更新信息到數(shù)據(jù)庫前,在應(yīng)用中執(zhí)行數(shù)據(jù)驗(yàn)證,這樣可減少錯(cuò)誤錄入,減少應(yīng)用程序與數(shù)據(jù)庫之間頻繁通信造成的服務(wù)器壓力。通過有效的數(shù)據(jù)驗(yàn)證,可以確認(rèn)寫入數(shù)據(jù)表中的數(shù)據(jù)是有效且符合預(yù)期的。本文我們將介紹如何通過C# 后端及JavaScript 前端對(duì) Web 控件進(jìn)行數(shù)據(jù)輸入有效性的驗(yàn)證。
范例運(yùn)行環(huán)境
操作系統(tǒng): Windows Server 2019 DataCenter
.net版本: .netFramework4.7.1 或以上
開發(fā)工具:VS2019 C#
驗(yàn)證設(shè)計(jì)
通過對(duì) Web 服務(wù)器控件捆綁自定義屬性 checkSchema="" 和 cName="",將自定義的校驗(yàn)類型和中文提示進(jìn)行賦值,即可完成驗(yàn)證的設(shè)置,可實(shí)現(xiàn)的校驗(yàn)類型如下圖所示:
多個(gè)數(shù)據(jù)校驗(yàn)類型請(qǐng)用“|”進(jìn)行分隔,如下設(shè)計(jì)舉例:
示例 1:不能為空且必須為日期型數(shù)據(jù)
<asp:TextBox id="x1" checkSchema="notnull|date" cName="出生日期" runat="server" />
示例 2:必須為身份證號(hào)
<asp:TextBox id="x1" checkSchema="idcard" runat="server" />
示例3:必須輸入4位的一個(gè)整型數(shù)
<asp:TextBox id="x1" checkSchema="mustlen4|int" runat="server" />
JavaScript 方法
設(shè)計(jì)
在前端客戶端,使用 JavaScript 方法 simplecheck 進(jìn)行數(shù)據(jù)驗(yàn)證,驗(yàn)證通過反回 true,否則為 false,其參數(shù)說明如下表:
序號(hào) | 參數(shù)名 | 類型 | 說明 |
---|---|---|---|
1 | chkobj | dom元素對(duì)象 | 如傳遞一個(gè) input type="text" 的對(duì)象 |
2 | _chkvalue | 字符串值 | dom元素對(duì)象的值,如 value 屬性值 |
3 | allowAlert | 布爾值 | 當(dāng)驗(yàn)證錯(cuò)誤時(shí)是否允許彈出alert提示框,true為允許 |
4 | etip | 字符串值 | 附加的前綴提示信息,后綴為方法提供的定義的錯(cuò)誤提示信息 |
實(shí)現(xiàn)
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 + '需要填寫內(nèi)容!'; break; case curSchema == 'number': check_result = isNumber(_chkvalue); curErrmsg = _cName + ' 輸入的數(shù)值不合理,請(qǐng)核對(duì)!'; break; case curSchema == 'bnumber': check_result = isBNumber(_chkvalue); curErrmsg = _cName + ' 輸入的數(shù)值應(yīng)為>=0的正數(shù),請(qǐng)核對(duì)!'; break; case curSchema == 'snumber': check_result = isSNumber(_chkvalue); curErrmsg = _cName + ' 輸入的數(shù)值應(yīng)為<0的負(fù)數(shù),請(qǐng)核對(duì)!'; break; case curSchema == 'date': check_result = isDate(_chkvalue, _cName); check_errid = 'date'; check_errmsg = (check_result ? '' : _cName + ' 輸入的日期不合理,請(qǐng)核對(duì)!'); 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 + ' 輸入的最小位數(shù)參數(shù)不合理,請(qǐng)與軟件供應(yīng)商聯(lián)系!'; } else { check_result = (_objlength < _slen ? false : true); curErrmsg = _cName + ' 的內(nèi)容要求最小輸入' + _slen + '位,請(qǐng)核對(duì)!'; } 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 + ' 輸入的最大位數(shù)參數(shù)不合理,請(qǐng)與軟件供應(yīng)商聯(lián)系!'; } else { check_result = (_objlength > _slen ? false : true); curErrmsg = _cName + ' 最大允許輸入' + _slen + '位,請(qǐng)核對(duì)!'; } 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 + ' 輸入的限制位數(shù)參數(shù)不合理,請(qǐng)與軟件供應(yīng)商聯(lián)系!'; } else { check_result = (_objlength != _slen ? false : true); curErrmsg = _cName + ' 的內(nèi)容輸入長度只能是' + _slen + '位,請(qǐng)核對(duì)!'; } break; case curSchema == 'time': check_result = validRegs(_chkvalue, /^\d{1,2}:\d{1,2}:\d{1,2}$/); curErrmsg = _cName + ' 輸入的時(shí)間不合理,請(qǐng)核對(duì)。'; break; case curSchema == 'alpha': check_result = isAlpha(_chkvalue); curErrmsg = _cName + ' 只能輸入的數(shù)字、字母和下劃線,請(qǐng)核對(duì)。'; break; case curSchema == 'mail': check_result = validRegs(_chkvalue, /^([a-zA-Z0-9._-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/); curErrmsg = _cName + ' 輸入的郵件地址不合理,請(qǐng)核對(duì)。'; break; case curSchema == 'phone': check_result = validRegs(_chkvalue, /([a-zA-Z0-9\.-\u4e00-\u9fa5]{8,})$/); curErrmsg = _cName + ' 輸入的電話號(hào)碼不合理,請(qǐng)核對(duì)。'; break; case curSchema == 'mobile': check_result = validRegs(_chkvalue, /^1(3[0-9]|5[012356789]|8[056789])\d{8}$/); curErrmsg = _cName + ' 輸入的手機(jī)號(hào)碼不合理,請(qǐng)核對(duì)。'; break; case curSchema == 'money': check_result = validRegs(_chkvalue, /^\d+(\.\d+)?$/); curErrmsg = _cName + ' 輸入的內(nèi)容不符合貨幣類型的要求,請(qǐng)核對(duì)。'; break; case curSchema == 'zip': check_result = validRegs(_chkvalue, /^[1-9]\d{5}$/); curErrmsg = _cName + ' 輸入的郵政編碼不合理,請(qǐng)核對(duì)。'; break; case curSchema == 'int': check_result = validRegs(_chkvalue, /^[-\+]?\d+$/); curErrmsg = _cName + ' 需要輸入一個(gè)整數(shù),請(qǐng)核對(duì)。'; break; case curSchema == 'en': check_result = validRegs(_chkvalue, /^[A-Za-z]+$/); curErrmsg = _cName + ' 只能輸入英文大小寫字母,請(qǐng)核對(duì)。'; break; case curSchema == 'cn': check_result = validRegs(_chkvalue, /^[\u0391-\uFFE5]+$/); curErrmsg = _cName + ' 只能輸入中文,請(qǐng)核對(duì)。'; break; case curSchema == 'url': check_result = validRegs(_chkvalue, /([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?/); curErrmsg = _cName + ' 輸入的網(wǎng)址不合理,請(qǐng)核對(duì)。'; 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; }
驗(yàn)證函數(shù)完整代碼如下:
function checkIdcard(idcard) { var _idcard = idcard; var Errors = new Array('', '身份證號(hào)碼位數(shù)不對(duì)!', '身份證號(hào)碼出生日期超出范圍或含有非法字符!', '身份證號(hào)碼校驗(yàn)錯(cuò)誤!', '身份證地區(qū)非法!', ''); if (_idcard == '') { return Errors[5]; } var area = { 11: '北京', 12: '天津', 13: '河北', 14: '山西', 15: '內(nèi)蒙古', 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: '臺(tái)灣', 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: '內(nèi)蒙古', 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: '臺(tái)灣', 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:非法地區(qū)'; 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:非法證號(hào)'; 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+'日期輸入不正確!日期部分應(yīng)為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]+',年月日部分必須輸入數(shù)字!'); 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+'年月日部分輸入的數(shù)字不合理,請(qǐng)核對(duì)!');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+',天數(shù)輸入范圍不合理!'); return false;}if(_month==2){ if(((_year%4==0)&&(_year%100!=0))||(_year%400==0)){ if(_day>29){if(!notip) alert(cname+'月份:'+_month+',天數(shù)輸入范圍不合理!');return false; }}else{ if(_day>28){if(!notip) alert(cname+'月份:'+_month+',天數(shù)輸入范圍不合理!');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]+$/, '');}
調(diào)用示例
假設(shè)對(duì) id 為 x1 的輸入框元素進(jìn)行身份證號(hào)驗(yàn)證,代碼如下:
if(simplecheck(document.getElementById('x1'),document.getElementById('x1').value, true,"您輸入的")==false){ return false; }
C# 方法
設(shè)計(jì)
客戶端檢驗(yàn)一般屬于弱檢驗(yàn),為保證數(shù)據(jù)的安全合法性,還需要在后端服務(wù)端進(jìn)行二次檢驗(yàn),使用 C# 方法 checkSchemaServerValid 進(jìn)行數(shù)據(jù)驗(yàn)證,驗(yàn)證通過返回空字符串信息,否則返回錯(cuò)誤提示信息,其參數(shù)說明如下表:
序號(hào) | 參數(shù)名 | 類型 | 說明 |
---|---|---|---|
1 | value | string | 要校驗(yàn)的數(shù)據(jù)值 |
2 | _checkSchema | string | 傳遞校驗(yàn)方案,即傳遞 Web 控件的自定義 checkSchema 屬性值 |
3 | _cName | string | 中文說明,即傳遞 web 控件的自定義 cName 屬性值 |
實(shí)現(xiàn)
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 + "需要填寫內(nèi)容!"; }else if(curSchema=="number") { curErrmsg =IsNumeric(value)?"":_cName + " 輸入的數(shù)值不合理,請(qǐng)核對(duì)!"; }else if(curSchema=="bnumber") { curErrmsg = IsBNumeric(value)?"":_cName +" 輸入的數(shù)值應(yīng)為>=0的正數(shù),請(qǐng)核對(duì)!"; }else if(curSchema=="snumber") { curErrmsg = IsSNumeric(value)?"":_cName + " 輸入的數(shù)值應(yīng)為<0的負(fù)數(shù),請(qǐng)核對(duì)!"; }else if(curSchema=="date") { curErrmsg = IsDate(value)?"": _cName + " 輸入的日期不合理,請(qǐng)核對(duì)!"; }else if(curSchema.IndexOf("minlen")!=-1) { int _slen =int.Parse(curSchema.Substring("minlen".Length, curSchema.Length - "minlen".Length)); curErrmsg= value.Length>= _slen ? "": _cName + " 的內(nèi)容要求最小輸入" + _slen.ToString() + "位,請(qǐng)核對(duì)!"; }else if(curSchema.IndexOf("maxlen")!=-1) { int _mlen =int.Parse(curSchema.Substring("maxlen".Length, curSchema.Length - "maxlen".Length)); curErrmsg= value.Length<= _mlen ? "": _cName + " 的內(nèi)容要求最大輸入" + _mlen.ToString() + "位,請(qǐng)核對(duì)!"; }else if(curSchema.IndexOf("mustlen")!=-1) { int _mlen =int.Parse(curSchema.Substring("mustlen".Length, curSchema.Length - "mustlen".Length)); curErrmsg= value.Length== _mlen ? "": _cName + " 的內(nèi)容輸入長度只能是" + _mlen.ToString() + "位,請(qǐng)核對(duì)!"; }else if(curSchema=="time"){ curErrmsg = IsDate(value)?"": _cName + " 輸入的時(shí)間不合理,請(qǐng)核對(duì)!"; }else if(curSchema=="alpha"){ curErrmsg =IsAlpha(value)?"": _cName + " 只能輸入的數(shù)字、字母和下劃線,請(qǐng)核對(duì)。"; }else if(curSchema=="mail"){ curErrmsg =IsEmail(value)?"": _cName + " 輸入的郵件地址不合理,請(qǐng)核對(duì)。"; }else if(curSchema=="phone"){ curErrmsg =IsPhone(value)?"": _cName + " 輸入的電話號(hào)碼不合理,請(qǐng)核對(duì)。"; }else if(curSchema=="mobile"){ curErrmsg =IsMobilePhone(value)?"":_cName + " 輸入的手機(jī)號(hào)碼不合理,請(qǐng)核對(duì)。"; }else if(curSchema=="money"){ curErrmsg =IsNumeric(value)?"": _cName + " 輸入的內(nèi)容不符合貨幣類型的要求,請(qǐng)核對(duì)。"; }else if(curSchema=="zip"){ curErrmsg =IsZip(value)?"": _cName + " 輸入的郵政編碼不合理,請(qǐng)核對(duì)。"; }else if(curSchema=="int"){ curErrmsg =IsInt(value)?"": _cName + " 需要輸入一個(gè)整數(shù),請(qǐng)核對(duì)。"; }else if(curSchema=="en"){ curErrmsg =IsEnglish(value)?"":_cName + " 只能輸入英文大小寫字母,請(qǐng)核對(duì)。"; }else if(curSchema=="cn"){ curErrmsg =IsChineseCh(value)?"": _cName + " 只能輸入中文,請(qǐng)核對(duì)。"; }else if(curSchema=="url"){ curErrmsg =IsURL(value)?"":_cName + " 輸入的網(wǎng)址不合理,請(qǐng)核對(duì)。"; }else if(curSchema=="idcard"){ curErrmsg =CheckIDCard(value)?"": _cName + " 請(qǐng)輸入合理的15或18位號(hào)碼。"; }else if(curSchema=="idcard18"){ curErrmsg =CheckIDCard18(value)?"": _cName + " 請(qǐng)輸入合理的18位號(hào)碼。"; }else if(curSchema=="idcard15"){ curErrmsg =CheckIDCard(value)?"": _cName + " 請(qǐng)輸入合理的15位號(hào)碼。"; }else if (curSchema == "an"){ curErrmsg = IsAN(value) ? "" : _cName + " 必須包含數(shù)字和字母。"; } check_errmsg = curErrmsg; if(check_errmsg!=""){ serverValidErrorType = curSchema; break; } } return check_errmsg; }
C#驗(yàn)證函數(shù)完整代碼如下:
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位身份證號(hào)碼驗(yàn)證 /// </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;//數(shù)字驗(yàn)證 } string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91"; if (address.IndexOf(idNumber.Remove(2)) == -1) { return false;//省份驗(yàn)證 } string birth = idNumber.Substring(6, 8).Insert(6, "-").Insert(4, "-"); DateTime time = new DateTime(); if (DateTime.TryParse(birth, out time) == false) { return false;//生日驗(yàn)證 } 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;//校驗(yàn)碼驗(yàn)證 } return true;//符合GB11643-1999標(biāo)準(zhǔn) } 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;//數(shù)字驗(yàn)證 } string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91"; if (address.IndexOf(idNumber.Remove(2)) == -1) { return false;//省份驗(yàn)證 } string birth = idNumber.Substring(6, 6).Insert(4, "-").Insert(2, "-"); DateTime time = new DateTime(); if (DateTime.TryParse(birth, out time) == false) { return false;//生日驗(yàn)證 } 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位區(qū)號(hào)的電話號(hào)碼,其中區(qū)號(hào)可以用小括號(hào)括起 /// 也可以不用,區(qū)號(hào)與本地號(hào)間可以用連字號(hào)或空格間隔, /// 也可以沒有間隔 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位身份證號(hào)碼驗(yàn)證 /// </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;//數(shù)字驗(yàn)證 } string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91"; if (address.IndexOf(idNumber.Remove(2)) == -1) { return false;//省份驗(yàn)證 } string birth = idNumber.Substring(6, 8).Insert(6, "-").Insert(4, "-"); DateTime time = new DateTime(); if (DateTime.TryParse(birth, out time) == false) { return false;//生日驗(yàn)證 } 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;//校驗(yàn)碼驗(yàn)證 } return true;//符合GB11643-1999標(biāo)準(zhǔn) } 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;//數(shù)字驗(yàn)證 } string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x61x14x32x41x50x62x15x33x42x51x63x21x34x43x52x64x65x71x81x82x91"; if (address.IndexOf(idNumber.Remove(2)) == -1) { return false;//省份驗(yàn)證 } string birth = idNumber.Substring(6, 6).Insert(4, "-").Insert(2, "-"); DateTime time = new DateTime(); if (DateTime.TryParse(birth, out time) == false) { return false;//生日驗(yàn)證 } return true; }
調(diào)用示例
假設(shè)對(duì) id 為 x1 的輸入框元素進(jìn)行身份證號(hào)驗(yàn)證,代碼如下:
string rv=checkSchemaServerValid(x1.Text,x1.Attributes["checkSchema"],"身份證號(hào)"); if(rv!=""){ Response.Write(rv); }else{ Response.Write("校驗(yàn)通過"); }
小結(jié)
本方法提供了一些基礎(chǔ)的且實(shí)用的驗(yàn)證類型方法,我們在實(shí)際的應(yīng)用中,可以通過擴(kuò)展自定義 checkSchema 屬性中提供的驗(yàn)證類型以滿足自己的應(yīng)用。
如何遍歷界面需要校驗(yàn)輸入字段,可通過 JavaScript 進(jìn)行控制,這里不再贅述。
以上就是C#結(jié)合JavaScript對(duì)Web控件進(jìn)行數(shù)據(jù)輸入驗(yàn)證的實(shí)現(xiàn)方法的詳細(xì)內(nèi)容,更多關(guān)于C# JavaScript Web數(shù)據(jù)驗(yàn)證的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
基于c# 類、接口、結(jié)構(gòu)的聯(lián)系與區(qū)別詳解
本篇文章是對(duì)c#中類與接口以及結(jié)構(gòu)的聯(lián)系與區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06C#微信公眾平臺(tái)開發(fā)之a(chǎn)ccess_token的獲取存儲(chǔ)與更新
這篇文章主要介紹了C#微信公眾平臺(tái)開發(fā)之a(chǎn)ccess_token的獲取存儲(chǔ)與更新的相關(guān)資料,需要的朋友可以參考下2016-03-03ajaxFileUpload插件,C#返回Json數(shù)據(jù)報(bào)錯(cuò)問題的解決方案
這篇文章主要介紹了ajaxFileUpload插件,C#返回Json數(shù)據(jù)報(bào)錯(cuò)的解決方案,需要的朋友可以參考下2017-12-12C#批量插入數(shù)據(jù)到sqlserver的方法詳解
這篇文章主要為大家詳細(xì)介紹了C#中四種可以批量插入數(shù)據(jù)到sqlserver的方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考一下2025-02-02C#簡單查詢SQLite數(shù)據(jù)庫是否存在數(shù)據(jù)的方法
這篇文章主要介紹了C#簡單查詢SQLite數(shù)據(jù)庫是否存在數(shù)據(jù)的方法,涉及C#調(diào)用SQLite組件及針對(duì)SQLite數(shù)據(jù)庫基本的連接、查詢、關(guān)閉等使用技巧,需要的朋友可以參考下2016-07-07C#使用DateTime.Now靜態(tài)屬性動(dòng)態(tài)獲得系統(tǒng)當(dāng)前日期和時(shí)間
本文主要介紹了C#使用DateTime.Now靜態(tài)屬性動(dòng)態(tài)獲得系統(tǒng)當(dāng)前日期和時(shí)間,DateTime結(jié)構(gòu)的Now靜態(tài)屬性只是得到一個(gè)系統(tǒng)時(shí)間對(duì)象,該時(shí)間對(duì)象不會(huì)隨著系統(tǒng)時(shí)間的變化而變化,如果要?jiǎng)討B(tài)顯示系統(tǒng)時(shí)間,可以使用計(jì)時(shí)器間隔地獲取系統(tǒng)時(shí)間對(duì)象并顯示,感興趣的可以了解一下2024-01-01