• js身份证验证算法


    var validateIdCard=function (id, backInfo) {
      var info={
        y: "1900",
        m: "01",
        d: "01",
        sex: "male",
        valid: false,
        length: 0
      },
      initDate=function (length) {
        info.length=length;
        var a=length===15?0:2,  // 15:18
          temp;
        info.y=(a?"":"19")+id.substring(6,8+a);
        info.m=id.substring(8+a,10+a);
        info.d=id.substring(10+a,12+a);
        info.sex=id.substring(14, 15+a)%2===0?"female":"male";
        temp=new Date(info.y, info.m-1, info.d);
        return (temp.getFullYear()==info.y*1)
         && (temp.getMonth()+1==info.m*1) 
         && (temp.getDate()==info.d*1);
      },
      back=function () {
        return backInfo?info:info.valid;
      };
      if(typeof id !== "string") return back();
      // 18
      if(/^d{17}[0-9x]$/i.test(id)){
        if(!initDate(18)) return back();
        id=id.toLowerCase().split("");
        var wi=[7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2],
          y="10x98765432".split(""),
          sum=0;
        for (var i = 0; i<17; i++) sum+=wi[i]*id[i];
        if(y[sum%11]===id.pop().toLowerCase()) info.valid=true;
        return back();
      }
      // 15
      else if(/^d{15}$/.test(id)){
        if(initDate(15)) info.valid=true;
        return back();
      }
      else{
        return back();
      }
    };


    validateIdCard(id, detail);
    string id: 身份证号码
    boolean detail: true-返回详细的计算结果,包括生日和性别等等 false-默认,返回验证结果
    example:





    身份证验证

    1、号码的结构
    公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
    2、地址码
    表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。(所有区域的编码可以到这个网站http://www.stats.gov.cn/tjbz/index.htm查询到最新的县及县以上的行政编码资料。)
    3、出生日期码
    表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。
    4、顺序码
    表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。
    5、校验码
    第十八位数字的计算方法为:
    1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2
    2.将这17位数字和系数相乘的结果相加。
    3.用加出来和除以11,看余数是多少
    4.余数只可能有0 1 2 3 4 5 6 7 8 9 10这11个数字。其分别对应的最后一位身份证的号码为1 0 X 9 8 7 6 5 4 3 2。
    5.通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码就是2。

    身份证号分为两种,旧的为15位,新的为18位。身份证15位编码规则:dddddd yymmdd xx p 其中 dddddd:地区码 yymmdd: 出生年月日 xx: 顺序类编码,无法确定 p: 性别,奇数为男,偶数为女; 身份证18位编码规则:dddddd yyyymmdd xxx y 其中 dddddd:地区码 yyyymmdd: 出生年月日 xxx:顺序类编码,无法确定,奇数为男,偶数为女 y: 校验码,该位数值可通过前17位计算获得,计算的公式见程序,一些需要用到的常数:18位号码加权因子为(从右到左) Wi = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2,1 ] 验证位 Y = [ 1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2 ] 校验位计算公式:Y_P = mod( ∑(Ai×Wi),11 ) i为身份证号码从右往左数的 2...18 位; Y_P为脚丫校验码所在校验码数组位置。



  • 相关阅读:
    JAVA 从一个List里删除包含另一个List的数据
    CentOS 常用命令合集
    010---软链接和硬链接
    009---linux进程管理
    008---vim编辑器
    007---归档、压缩、解压缩
    006---Linux用户、群组和权限
    005---Linux文件与目录管理
    001---Linux系统的启动过程
    002---Linux系统目录结构
  • 原文地址:https://www.cnblogs.com/lianer/p/4609148.html
Copyright © 2020-2023  润新知