|
<><A href="http://www.netbei.com/Soft/asp/asp10/200507/1432.html"><FONT color=#ff0000><STRONG>点击下载此程序</STRONG></FONT></A></P>
<>18位身份证校验算法 <BR>身份证校验码算法 <BR>身份证校验码产生方法:<BR>∑(ai×Wi)(mod 11)<BR><BR>i: 表示号码字符从由至左包括校验码在内的位置序号;<BR><BR>ai 表示第i位置上的号码字符值;<BR><BR>Wi 第i位置上的加权因子,其数值Wi=mod(power(2,(n-1)),11)<BR><BR>i 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1<BR>Wi 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 1<BR><BR>相应的校验码:<BR>∑(ai×WI)(mod 11) 0 1 2 3 4 5 6 7 8 9 10<BR>校验码字符值ai 1 0 X 9 8 7 6 5 4 3 2<BR><BR>下面是校验函数:<BR><BR>FUNCTION sfzjy(num)<BR>if len(num)=15 then<BR>cID = left(num,6)&"19"&right(num,9)<BR> elseif len(num)=17 or len(num)=18 then<BR>cID = left(num,17)<BR> end if <BR>nSum=mid(cID,1,1) * 7<BR>nSum=nsum+mid(cID,2,1) * 9 <BR>nSum=nsum+mid(cID,3,1) * 10 <BR>nSum=nsum+mid(cID,4,1) * 5 <BR>nSum=nsum+mid(cID,5,1) * 8 <BR>nSum=nsum+mid(cID,6,1) * 4<BR>nSum=nsum+mid(cID,7,1) * 2<BR>nSum=nsum+mid(cID,8,1) * 1<BR>nSum=nsum+mid(cID,9,1) * 6<BR>nSum=nsum+mid(cID,10,1) * 3<BR>nSum=nsum+mid(cID,11,1) * 7<BR>nSum=nsum+mid(cID,12,1) * 9<BR>nSum=nsum+mid(cID,13,1) * 10<BR>nSum=nsum+mid(cID,14,1) * 5<BR>nSum=nsum+mid(cID,15,1) * 8<BR>nSum=nsum+mid(cID,16,1) * 4<BR>nSum=nsum+mid(cID,17,1) * 2<BR>'*计算校验位<BR>check_number=12-nsum mod 11<BR>If check_number=10 then<BR> check_number="X"<BR>End if<BR>If check_number=12 then<BR> check_number="1"<BR>End if<BR>If check_number=11 then<BR> check_number="0"<BR>End if<BR>sfzjy=check_number<BR>End function<BR><BR><BR><BR>其它校验:<BR>性别与出生年月:<BR><BR>sfznum=身份证号码<BR>lenx=len(sfznum) <BR> if lenx=15 then <BR> yy="19"&mid(xian,7,2)<BR> mm=mid(xian,9,2)<BR> dd=mid(xian,11,2)<BR> aa=mid(xian,15,1) '15位身分证取第十五位,能被2整除为女性<BR><BR> end if <BR> if lenx=18 then<BR> yy=mid(xian,7,4)<BR> mm=mid(xian,11,2)<BR> dd=mid(xian,13,2)<BR> aa=mid(xian,17,1) '18位身分证取第十七位,能被2整除为女性<BR> end if <BR>if aa mod 2=0 then <BR> xb="女"<BR> else<BR> xb="男"<BR>end if <BR><BR>if lenx=18 then<BR>if mid(xian,18,1)<>cstr(sfzjy(xian)) then '如果第十八位校验码不等于计算出的校验码则身份证号码有误.<BR> response.write "提示:身份证校验位错误!"<BR> else<BR> response.write "结果:身份证号码校验为合法号码!" <BR>end if<BR> else '如果输入的是十五位号,则计算出十八位新号<BR> response.write "新身份证:"&left(xian,6)&"19"&right(xian,9)&cstr(sfzjy(xian))<BR>end if<BR><BR>关于户籍判断则而要<A class=Channel_KeyLink href="http://www.netbei.com/Article/db/Index.html">数据库</A>.这里就不提供了.</P> |
|