算法:
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();
用身份证校验位检验身份证正确性

本文介绍了如何使用算法和代码来验证身份证号码的正确性,通过将身份证号码的每位与特定权重相乘求和,再用模11运算得到校验位,以此判断身份证号码的合法性。
最低0.47元/天 解锁文章
837

被折叠的 条评论
为什么被折叠?



