当前位置: 移动技术网 > IT编程>开发语言>Asp > 身份证校验算法与ASP程序

身份证校验算法与ASP程序

2017年12月12日  | 移动技术网IT编程  | 我要评论
18位身份证校验算法 
身份证校验码算法 
身份证校验码产生方法:
∑(ai×wi)(mod 11)

i: 表示号码字符从由至左包括校验码在内的位置序号;

ai 表示第i位置上的号码字符值;

wi 第i位置上的加权因子,其数值wi=mod(power(2,(n-1)),11)

i 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
wi 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 1

相应的校验码:
∑(ai×wi)(mod 11) 0 1 2 3 4 5 6 7 8 9 10
校验码字符值ai 1 0 x 9 8 7 6 5 4 3 2

下面是校验函数:

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

关于户籍判断则而要数据库.这里就不提供了.

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网