通过身份证校验位检验身份证正确性

本文介绍了如何使用算法和代码来验证身份证号码的正确性,通过将身份证号码的每位与特定权重相乘求和,再用模11运算得到校验位,以此判断身份证号码的合法性。
摘要由CSDN通过智能技术生成

算法:

W[] = 7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2
∑(a[i]×W[i])(mod 11)
校验位:1 0 X 9 8 7 6 5 4 3 2
举个栗子:
身份证号:102154198801238569
a[] = 10215419880123856
身份证每一位和W[]每一位相乘后求和,模除以11,取校验位相应的位数即可

代码

package utils;

import java.text.ParseException;
import java.text.SimpleDateFormat;

/**
 * Created by lwg
 */
public class BankUtils {
   
    /**
     * 校验身份证号
     *
     * @param idCardNo 身份证号
     * @return true通过,false未通过
     */
    public static boolean checkIdCardNo(String idCardNo) {
        if (null == idCardNo) {
            return false;
        }
        idCardNo = idCardNo.toLowerCase();
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值