//身份证号码校验函数
func tioncheck Idcar d2(id card){
var Erro rs=ne w Arr ay(
"验证通过!",
"身份证号码位数不对!",
"身份证号码出生日期超出范围或含有非法字符!",
"身份证号码校验错误!",
"身份证地区非法!"
);
var a rea={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 i dcard,Y,JY M;
va r S,M;
var idca rd_ar ray = newArray();
i dcard_arra y = i dcard.spli t("");
//地区检验
i f(are a[par seInt(idca rd.su bstr(0,2))]==nu ll)
{
ale rt(Er rors[4]);
retur n fal se ;
}
//身份号码位数及格式检验
swi tch(i dcard.leng th){
case15:
i f ( (parse Int(i dcard.subs tr(6,2))+1900)% 4 == 0 ||
((p arseI nt(id card.subst r(6,2))+1900) % 100== 0&&
(p arseI nt(id card.subst r(6,2))+1900) % 4 == 0 )){
ere g=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-
html怎么实现登录验证功能1])|(04|06|09|11)(0[1-9]|[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性
} e lse {
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(e reg.t est(i dcard)) re turntrue;
else
{
al ert(E rrors[2]);
retu rn fa lse;
b reak;
case 18:
//18位身份号码检测
//出生日期的合法性检查
/
/闰年月日:((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]))
//平年月日:((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]))
if ( pars eInt(idcar d.sub str(6,4))% 4 == 0 || (pa rseIn t(idc ard.s ubstr(6,4)) % 100 == 0 && pars eInt(idcar d.sub str(6,4))%4 ==0 )){
ereg=/^[1-9][0-9]{5}(19|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]$/;//闰年出生日期的合法性正则表达式
} els e {
e reg=/^[1-9][0-9]{5}(19|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(idca rd)){//测试出生日期的合法性
//计算校验位
S =(pars eInt(idcar d_arr ay[0]) + p arseI nt(id card_array[10])) * 7
+ (p arseI nt(id card_array[1])+ par seInt(idca rd_ar ray[11]))* 9
+ (par seInt(idca rd_ar ray[2]) +parse Int(i dcard_arra y[12])) *10
+(pars eInt(idcar d_arr ay[3]) + p arseI nt(id card_array[13])) * 5
+ (p arseI nt(id card_array[4])+ par seInt(idca rd_ar ray[14]))* 8
+ (par seInt(idca rd_ar ray[5]) +parse Int(i dcard_arra y[15])) *4
+ (parse Int(i dcard_arra y[6]) + pa rseIn t(idc ard_a rray[16])) * 2
+ par seInt(idca rd_ar ray[7]) *1
+parse Int(i dcard_arra y[8]) * 6
+ par seInt(idca rd_ar ray[9]) *3 ;
Y = S% 11;
M ="F";
JYM = "10X98765432";
M =JYM.s ubstr(Y,1);//判断校验位
i f(M == idc ard_a rray[17])retur n tru e; //检测ID的校验位
e lse
{ aler t(Err ors[3]);
r eturn fals e;
}
}
els e
{
alert(Erro rs[2]);
re turnfalse;
break;
def ault:
aler t(Err ors[1]); r eturn fals e ; break;
}
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论