FUNCTION sfzjy(num) if len(num)=15 then cID = left(num,6)"19"right(num,9) elseif len(num)=17 or len(num)=18 then cID = left(num,17) end if nSum=mid(cID,1,1) * 7 nSum=nsum+mid(cID,2,1) * 9 nSum=nsum+mid(cID,3,1) * 10 nSum=nsum+mid(cID,4,1) * 5 nSum=nsum+mid(cID,5,1) * 8 nSum=nsum+mid(cID,6,1) * 4 nSum=nsum+mid(cID,7,1) * 2 nSum=nsum+mid(cID,8,1) * 1 nSum=nsum+mid(cID,9,1) * 6 nSum=nsum+mid(cID,10,1) * 3 nSum=nsum+mid(cID,11,1) * 7 nSum=nsum+mid(cID,12,1) * 9 nSum=nsum+mid(cID,13,1) * 10 nSum=nsum+mid(cID,14,1) * 5 nSum=nsum+mid(cID,15,1) * 8 nSum=nsum+mid(cID,16,1) * 4 nSum=nsum+mid(cID,17,1) * 2 '*计算校验位 check_number=12-nsum mod 11 If check_number=10 then check_number="X" elseIf check_number=12 then check_number="1" elseif check_number=11 then check_number="0" End if sfzjy=check_number End function
其它校验: 性别与出生年月:
sfznum=身份证号码 lenx=len(sfznum) if lenx=15 then yy="19"mid(xian,7,2) mm=mid(xian,9,2) dd=mid(xian,11,2) aa=mid(xian,15,1) '15位身分证取第十五位,能被2整除为女性
end if if lenx=18 then yy=mid(xian,7,4) mm=mid(xian,11,2) dd=mid(xian,13,2) aa=mid(xian,17,1) '18位身分证取第十七位,能被2整除为女性 end if if aa mod 2=0 then xb="女" else xb="男" end if
if lenx=18 then if mid(xian,18,1)>cstr(sfzjy(xian)) then '如果第十八位校验码不等于计算出的校验码则身份证号码有误. response.write "提示:身份证校验位错误!" else response.write "结果:身份证号码校验为合法号码!" end if else '如果输入的是十五位号,则计算出十八位新号 response.write "新身份证:"left(xian,6)"19"right(xian,9)cstr(sfzjy(xian)) end if