身份证算法(转)

转自:http://www.hotine.org/wordpress/archives/56

1、号码的结构
 公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
 2、地址码
 表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。
 3、出生日期码
 表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。
 4、顺序码
 表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配
 给女性。
 5、校验码
 (1)十七位数字本体码加权求和公式
 S = Ai * Wi, i = 2, ... , 18
 Y = mod(S, 11)
 i: 表示号码字符从右至左包括校验码字符在内的位置序号
 Ai:表示第i位置上的身份证号码字符值
 Wi:表示第i位置上的加权因子
 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
 (2)校验码字符值的计算
 Y: 0 1 2 3 4 5 6 7 8 9 10
 校验码: 1 0 X 9 8 7 6 5 4 3 2

JavaScript版:

 //18身份证末位生成
 iW = new Array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2,1);
 iSum = 0;
 for( i=0;i<17;i++)
 {
 iC = IDNumber.charAt(i) ;
 iVal = parseInt(iC);
 iSum += iVal * iW[i];
 }
 iJYM = iSum % 11;
 var sJYM = "";
 if(iJYM == 0) sJYM = "1";
 else if(iJYM == 1) sJYM = "0";
 else if(iJYM == 2) sJYM = "x";
 else if(iJYM == 3) sJYM = "9";
 else if(iJYM == 4) sJYM = "8";
 else if(iJYM == 5) sJYM = "7";
 else if(iJYM == 6) sJYM = "6";
 else if(iJYM == 7) sJYM = "5";
 else if(iJYM == 8) sJYM = "4";
 else if(iJYM == 9) sJYM = "3";
 else if(iJYM == 10) sJYM = "2";
 alert(sJYM);

 

说明一下,加权因子的算法是2^(n-1) 与11取余,2^(18-1)%11 = 7,2^(17-1)%11 = 9,2^(16-1)%11=10......

,n表示倒序位置数,如此类推便计算出加权因子

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值