import java.util.Scanner; /** * */ /** * @author hanson * */ /** * 1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7910584216379105842 * 2.将这17位数字和系数相乘的结果相加。 * 3.用加出来和除以11,看余数是多少? * 4余数只可能有012345678910这11个数字。其分别对应的最后一位身份证的号码为10X98765432。 * 5.通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码就是2。 * @author hanson * */ /** * 身份证验证类 * @author hanson * */ public class IdCard { /** * 程序的主方法,入口。获取用户输入并输出验证结果 * @param args 参数数组 */ public static void main(String[] args) { Scanner strReader=new Scanner(System.in); String idStr=strReader.nextLine(); if(check(idStr)){ System.out.println("身份证验证正确"); } else{ System.err.println("对不起,这不是合法的身份证,请检查输入 !"); } } /** * 求出身份证每一位加权乘积之和 * @param idStr 身份证号码 * @return 加权乘积之和 */ private static int product(String idStr){ int[] interest=new int[]{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};//各位的权重 char[] id=idStr.toCharArray();//将身份证各位提取为字符数组 int products=0; for(int i=0;i<17;i++){ products=products+interest[i]*(id[i]-'0'); } return products; } /** * 对乘积之和进行求余并匹配最后的一位数字 * @param product 各位加权乘积之和 * @return 返回最后一个数字 */ private static char match(int product){ char[] last=new char[]{'1','0','x','9','8','7','6','5','4','3','2'};//末尾匹配 return last[product%11]; } /** * 将通过计算得到的最后一位数字和身份证号码的最后一位进行对比 * @param idStr 身份证号码 * @return 如果是相同的,则表示是正确的,返回true,如果两个数字不一样就返回false */ private static boolean check(String idStr){ if(idStr.charAt(17)==match(product(idStr))){ return true; } else{ return false; } } }
转载于:https://www.cnblogs.com/yixuezi/archive/2012/08/12/2634232.html