使用JS 校验15或18位身份证的合法性以及得到所属地区,出生日期,性别

/** 
 * 身份证15位编码规则:dddddd yymmdd xx p
 * dddddd:地区码
 * yymmdd: 出生年月日
 * xx: 顺序类编码,无法确定
 * p: 性别,奇数为男,偶数为女
 * <p />
 * 身份证18位编码规则:dddddd yyyymmdd xxx y
 * dddddd:地区码
 * yyyymmdd: 出生年月日
 * xxx:顺序类编码,无法确定,奇数为男,偶数为女
 * y: 校验码,该位数值可通过前17位计算获得
 * <p />
 * 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为校验码所在校验码数组位置
 *
 */
// 加权因子
var wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1];
// 身份证验证位值.10代表X   
var valideCodeArr = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; 
// 区域ID
var areaMap = {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:"国外"};
// 男女ID
var sexMap = {0:"女",1:"男"};
//错误信息
var status = new Array("true", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!");


/**
 * 验证ID,正确返回“true”,错误则返回错误信息
 * @param {Object} idCard
 */
function checkIdCard(idCard){
	//去掉首尾空格
    idCard = trim(idCard.replace(/ /g, ""));
	
	if (idCard.length == 15||idCard.length == 18) {
		if (!checkArea(idCard)) {
			return status[4];
		} else if(!checkBrith(idCard)){
			return status[2];
		} else if(idCard.length == 18 && !check18Code(idCard)){
			return status[3];
		} else {
			return status[0];
		}
    } else {
		//不是15或者18,位数不对
        return status[1];
    }
}


/**
 * 显示解析出的信息
 * @param {Object} idCard 正确的ID号
 * @param {Object} sexId 性别要显示的Input的id
 * @param {Object} birthId 生日要显示的Input的id
 * @param {Object} areaId 地区要显示的Input的id
 */
function showIDInfo(idCard,areaId,sexId, birthId){
	// 对身份证号码做处理。包括字符间有空格。
    idCard = trim(idCard.replace(/ /g, ""));
	
	// 性别
	$("#"+sexId).val(getSex(idCard));
	// 地区
   	$("#"+areaId).val(getArea(idCard));
	//生日
	$("#"+birthId).val(getBirthday(idCard));
}


/**
 * 得到地区码代表的地区 
 * @param {Object} idCard 正确的15/18位身份证号码
 */
function getArea(idCard){
	return areaMap[parseInt(idCard.substr(0, 2))];
}

/** 
 * 通过身份证得到性别
 * @param idCard 正确的15/18位身份证号码
 * @return 女、男
 */
function getSex(idCard){
    if (idCard.length == 15) {
        return sexMap[idCard.substring(14, 15) % 2];
    } else if (idCard.length == 18) {
        return sexMap[idCard.substring(14, 17) % 2];
    } else {
		//不是15或者18,null
        return null;
    }
}

/**
 * 得到生日"yyyy-mm-dd"
 * @param {Object} idCard 正确的15/18位身份证号码
 */
function getBirthday(idCard){
	var birthdayStr;

    if (15 == idCard.length) {
        birthdayStr = idCard.charAt(6) + idCard.charAt(7);
		
        if (parseInt(birthdayStr) < 10) {
            birthdayStr = '20' + birthdayStr;
        } else {
            birthdayStr = '19' + birthdayStr;
        }
        birthdayStr = birthdayStr + '-' + idCard.charAt(8) + idCard.charAt(9) + '-' + idCard.charAt(10) + idCard.charAt(11);
    }else if (18 == idCard.length) {
        birthdayStr = idCard.charAt(6) + idCard.charAt(7) + idCard.charAt(8) + idCard.charAt(9) + '-' + idCard.charAt(10) + idCard.charAt(11) + '-' + idCard.charAt(12) + idCard.charAt(13);
    }
	
	return birthdayStr;
}

/**
 * 验证身份证的地区码
 * @param {Object} idCard 身份证字符串
 */
function checkArea(idCard){
	if(areaMap[parseInt(idCard.substr(0, 2))] == null){
		return false;
	} else {
		return true;
	}
}

/** 
 * 验证身份证号码中的生日是否是有效生日
 * @param idCard 身份证字符串
 * @return
 */
function checkBrith(idCard){
	var result = true;
	
	if (15 == idCard.length) {
	    var year = idCard.substring(6, 8);
	    var month = idCard.substring(8, 10);
	    var day = idCard.substring(10, 12);
	    var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
	   
	    // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法  
	    if (temp_date.getYear() != parseFloat(year) || temp_date.getMonth() != parseFloat(month) - 1 || temp_date.getDate() != parseFloat(day)) {
	        result =  false;
	    }
	} else if (18 == idCard.length) {
	    var year = idCard.substring(6, 10);
	    var month = idCard.substring(10, 12);
	    var day = idCard.substring(12, 14);
	    var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
	    
		// 这里用getFullYear()获取年份,避免千年虫问题  
	    if (temp_date.getFullYear() != parseFloat(year) || temp_date.getMonth() != parseFloat(month) - 1 || temp_date.getDate() != parseFloat(day)) {
	        result = false;
	    }
	} else {
		result = false;
	}
	
	return result;
}

/** 
 * 判断身份证号码为18位时最后的验证位是否正确
 * @param idCardArr 身份证号码数组
 * @return
 */
function check18Code(idCardArr){
    var sum = 0; // 声明加权求和变量
    
    if (idCardArr[17].toLowerCase() == 'x') {
        idCardArr[17] = 10;// 将最后位为x的验证码替换为10方便后续操作  
    }
	
    for (var i = 0; i < 17; i++) {
        sum += wi[i] * idCardArr[i];// 加权求和  
    }
	
    var valCodePosition = sum % 11;// 得到验证码所位置
    if (idCardArr[17] == valideCodeArr[valCodePosition]) {
        return true;
    } else {
        return false;
    }
}

//去掉字符串头尾空格  
function trim(str){
    return str.replace(/(^\s*)|(\s*$)/g, "");
}

==================== 下面是页面代码 =====================

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <title>CordBirthday</title>
		<script type="text/javascript" src="jquery-1.4.4.min.js"></script>
        <script type="text/javascript"  src="IDVerifier.js"></script>
        <script type="text/javascript">
            function validite(){
                var id = $("#idCard").val();
				var resultstr = checkIdCard(id);

                if (resultstr == "true") {
                    showIDInfo(id,"area" ,"sex", "birthday");
                } else {
					$('#sex').val("");
                    $('#birthday').val("");
                    $('#area').val("");
					alert(resultstr);
                }
            }
        </script>
    </head>
    <body>
        <form>
            <table align="center">
                <tr>
                    <td align="center">
                        身份证<input type="text" id="idCard">
                    </td>
                </tr>
                <tr>
                    <td align="center">
                        地区<input type="text" id="area">
                    </td>
                </tr>
                <tr>
                    <td align="center">
                        性别<input type="text" id="sex">
                    </td>
                </tr>
                <tr>
                    <td align="center">
                        生日<input type="text" id="birthday">
                    </td>
                </tr>
                <tr>
                    <td align="center">
                        <input type="button" value="OK" οnclick="validite()">
                    </td>
                </tr>
            </table>
        </form>
    </body>
</html>

附上JS判断布尔表达式的方式

1> 如果比较的两者中有bool,会把 bool 先转换为对应的 number,即 0 和 1。

2> 如果比较的双方中有一方为number一方为string,会把string转换为数字。
3> 把string直接转换为bool的时候,空字符串‘’转换为 false,除此外的一切字符串转换为 true。
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值