• js中验证身份证号码是否正确支持15位和18位身份证号


    做判断的时候总会遇到要效验身份证号码正不正确的问题,所有特地百度搜搜,整理,能实现身份证号长度校验、身份证号地址编码校验、身份证号中的年月日并校验。

    身份证号码的特殊含义如下:

    1.前1、2位数字表示:所在省份的代码;

    2.第3、4位数字表示:所在城市的代码;

    3.第5、6位数字表示:所在区县的代码;

    4.第7~14位数字表示:出生年、月、日;

    5.第15、16位数字表示:所在地的派出所的代码;

    6.第17位数字表示性别:奇数表示男性,偶数表示女性;

    7.第18位数字是校检码:也有的说是个人信息码,不是随计算机的随机产生,它是 用来检验身份证的正确性。校检码可以是0—9的数字,有时也用x表示。作为尾号的校验码,是由号码编制单位按统一的公式计算出来的,如果某人的尾号是0-9,都不会出现X,但如果尾号是10,那么就得用X来代替,因为如果用10做尾号,那么此人的身份证就变成了19位。X是罗马数字的10,用X来代替10,可以保证公民的身份证符合国家标准。

    /*
     * cardRequired.js
     * 身份证号校验&&必填
     * val    value
     * 身份证号合法性验证    支持15位和18位身份证号    //支持地址编码、出生日期、校验位验证
     * Y J
     * 
     */
    var cardRequired =function(val) {
        var b = "",
            c = "",
            d = {};
        /*身份证号长度校验*/
        if(!/(^d{15}$)|(^d{17}(d|X|x)$)/.test(val)) {
            return {
                is: false,
     
                tip: "你输入的身份证长度或格式错误!"
     
            }
     
        };
        /*身份证号地址编码校验*/
        if(!/^11|12|13|14|15|21|22|23|31|32|33|34|35|36|37|41|42|43|44|45|46|50|51|52|53|54|61|62|63|64|65|71|81|82|91$/.test(val.substr(0, 2))) {
                return {
                    is: false,
                    tip: "你输入的身份证号地址编码错误!"
                }
           };
           /*15位身份证号转18位身份证号*/
        var a18 = val;
        if(val.length == '15') {
            var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
            var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2');
            var cardTemp = 0,
            i;
            a18 = ""
            a18 = val.substr(0, 6) + '19' + val.substr(6, val.length - 6);
            for(i = 0; i < 17; i++) {
                cardTemp += a18.substr(i, 1) * arrInt[i];
            }
            a18 += arrCh[cardTemp % 11];
        }
        /*获取身份证号中的年月日并校验*/
        var re_eighteen = /^(d{6})(d{4})(d{2})(d{2})(d{3})([0-9]|X|x)$/;
        var arr_data = a18.match(re_eighteen);
        var year = arr_data[2];
        var month = arr_data[3];
        var day = arr_data[4];
        var birthday = new Date(year + '/' + month + '/' + day);
        var now = new Date();
        var time = now.getFullYear() - year;
        /*校验年月日是否合理 */
        if(birthday.getFullYear() == year && (birthday.getMonth() + 1) == month && birthday.getDate() == day) {
            if(time >= 0 || time <= 130) {
                return {
                    is: "true",
                    tip: ""
                }
            }
        };
        return {
            is: false,
            tip: "你输入的身份证号出生年月日不合理!"
        }
    }
  • 相关阅读:
    hdu4725 The Shortest Path in Nya Graph
    poj2679 Adventurous Driving 最短路
    线段树完全版【代码集合
    LCS!LCS!
    bzoj2763: [JLOI2011]飞行路线
    bzoj3389: [Usaco2004 Dec]Cleaning Shifts安排值班
    [ 浙江大学 数据库系统原理 ] [ MiniSQL ]课程设计
    [ 浙江大学 程序设计专题 ] 四个专题代码 报告 PPT共享
    [ C语言 ] 迷宫 迷宫生成器 [ 递归与搜索 ]
    [ C语言版 ] 数独计算器 [ 搜索剪枝法 ]
  • 原文地址:https://www.cnblogs.com/feipengting/p/13032944.html
Copyright © 2020-2023  润新知