18位身份证校验

//java-校验18位身份证号
	public static boolean checkIdCard18(String value) {
		if(value==null||value.length() !=18){
			return false;
		}
		int[] arrExp =new int[]{7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};//加权因子
		String[] arrValid =new String[]{"1", "0", "X", "9", "8", "7", "6", "5", "4", "3", "2"}; //校验码
		String reg="^\\d{17}[\\d|X|x$]";
		if(value.matches(reg)){
			int sum = 0, idx;
			for(int i = 0; i < value.length() - 1; i++){
				// 对前17位数字与权值乘积求和
				sum += Integer.parseInt(value.substring(i, (i+1)), 10) * arrExp[i];
			}
			// 计算模(固定算法)
			idx = sum % 11;
			// 检验第18为是否与校验码相等
			return arrValid[idx].equals(value.substring(17).toUpperCase());
		}else{
			return false;
		}
	}
//js-校验18位身份证号
function check_id_card(value){
    if(!value||value.length !=18){
        return false;
    }
    var arrExp = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];//加权因子
    var arrValid = [1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2];//校验码
    if(/^\d{17}\d|X|x$/i.test(value)){
        var sum = 0, idx;
        for(var i = 0; i < value.length - 1; i++){
            // 对前17位数字与权值乘积求和
            sum += parseInt(value.substr(i, 1), 10) * arrExp[i];
        }
        // 计算模(固定算法)
        idx = sum % 11;
        console.log(arrValid[idx])
        // 检验第18为是否与校验码相等
        return arrValid[idx] == value.substr(17, 1).toUpperCase();
    }else{
        return false;
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值