软工 任务2
Posted Vincent丶56
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软工 任务2相关的知识,希望对你有一定的参考价值。
任务选择一、实现模块判断传入的身份证号码的正确性;
一、实现功能模块;
身份证验证的工具(支持15位或18位身份证)
身份证号码结构:
17位数字和1位校验码:6位地址码数字,8位生日数字,3位出生时间顺序号,1位校验码。
地址码(前6位):表示对象常住户口所在县(市、镇、区)的行政区划代码,按GB/T2260的规定执行。
出生日期码,(第七位 至十四位):表示编码对象出生年、月、日,按GB按GB/T7408的规定执行,年、月、日代码之间不用分隔符。
顺序码(第十五位至十七位):表示在同一地址码所标示的区域范围内,对同年、同月、同日出生的人编订的顺序号,
顺序码的奇数分配给男性,偶数分配给女性。
校验码(第十八位数):
十七位数字本体码加权求和公式 s = sum(Ai*Wi), i = 0,,16,先对前17位数字的权求和;
Ai:表示第i位置上的身份证号码数字值.Wi:表示第i位置上的加权因.Wi: 7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2;
计算模 Y = mod(S, 11)
通过模得到对应的校验码 Y: 0 1 2 3 4 5 6 7 8 9 10 校验码: 1 0 X 9 8 7 6 5 4 3 2
二、针对所实现的模块编写对应的单元测试代码;
1 package CheckCard; 2 import java.util.Calendar; 3 import java.util.HashMap; 4 import java.util.Map; 5 import javax.xml.bind.Validator; 6 7 public class CheckCard { 8 final static Map<Integer, String> zoneNum = new HashMap<Integer, String>(); 9 static { 10 zoneNum.put(11, "北京"); 11 zoneNum.put(12, "天津"); 12 zoneNum.put(13, "河北"); 13 zoneNum.put(14, "山西"); 14 zoneNum.put(15, "内蒙古"); 15 zoneNum.put(21, "辽宁"); 16 zoneNum.put(22, "吉林"); 17 zoneNum.put(23, "黑龙江"); 18 zoneNum.put(31, "上海"); 19 zoneNum.put(32, "江苏"); 20 zoneNum.put(33, "浙江"); 21 zoneNum.put(34, "安徽"); 22 zoneNum.put(35, "福建"); 23 zoneNum.put(36, "江西"); 24 zoneNum.put(37, "山东"); 25 zoneNum.put(41, "河南"); 26 zoneNum.put(42, "湖北"); 27 zoneNum.put(43, "湖南"); 28 zoneNum.put(44, "广东"); 29 zoneNum.put(45, "广西"); 30 zoneNum.put(46, "海南"); 31 zoneNum.put(50, "重庆"); 32 zoneNum.put(51, "四川"); 33 zoneNum.put(52, "贵州"); 34 zoneNum.put(53, "云南"); 35 zoneNum.put(54, "西藏"); 36 zoneNum.put(61, "陕西"); 37 zoneNum.put(62, "甘肃"); 38 zoneNum.put(63, "青海"); 39 zoneNum.put(64, "新疆"); 40 zoneNum.put(71, "台湾"); 41 zoneNum.put(81, "香港"); 42 zoneNum.put(82, "澳门"); 43 zoneNum.put(91, "外国"); 44 } 45 final static int[] PARITYBIT = {\'1\', \'0\', \'X\', \'9\', \'8\', \'7\', \'6\', \'5\', \'4\', \'3\', \'2\'}; 46 final static int[] POWER_LIST = { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 47 5, 8, 4, 2}; 48 /** 49 * 50 * 身份证验证 51 * 52 *@param s 53 * 号码内容 54 *@return 是否有效 null和"" 都是false 55 */ 56 public static boolean isIdcard(String s){ 57 if(s == null || (s.length() != 15 && s.length() != 18)) 58 return false; 59 final char[] cs = s.toUpperCase().toCharArray(); 60 //校验位数 61 int power = 0; 62 for(int i=0; i<cs.length; i++){ 63 if(i==cs.length-1 && cs[i] == \'X\') 64 break;//最后一位可以 是X或x 65 if(cs[i]<\'0\' || cs[i]>\'9\') 66 return false; 67 if(i < cs.length -1){ 68 power += (cs[i] - \'0\') * POWER_LIST[i]; 69 } 70 } 71 //校验区位码 72 if(!zoneNum.containsKey(Integer.valueOf(s.substring(0,2)))){ 73 return false; 74 } 75 //校验年份 76 String year = s.length() == 15 ? "19" + s.substring(6,8) :s 77 .substring(6, 10); 78 final int iyear = Integer.parseInt(year); 79 if(iyear < 1900 || iyear > Calendar.getInstance().get(Calendar.YEAR)) 80 return false;//1900年的PASS,超过今年的PASS 81 //校验月份 82 String month = s.length() == 15 ? s.substring(8, 10) : s.substring(10,12); 83 final int imonth = Integer.parseInt(month); 84 if(imonth <1 || imonth >12){ 85 return false; 86 } 87 //校验天数 88 String day = s.length() ==15 ? s.substring(10, 12) : s.substring(12, 14); 89 final int iday = Integer.parseInt(day); 90 if(iday < 1 || iday > 31) 91 return false; 92 //校验一个合法的年月日 93 if(!validate(iyear, imonth, iday)) 94 return false; 95 //校验"校验码" 96 if(s.length() == 15) 97 return true; 98 return cs[cs.length -1 ] == PARITYBIT[power % 11]; 99 } 100 static boolean validate(int year, int imonth, int iday){ 101 //比如考虑闰月,大小月等 102 return true; 103 } 104 public static void main(String[] args) { 105 for(int i=0;i<10;i++){ 106 final String s = "330482199607070616"; 107 System.out.println(s+" --> "+isIdcard(s)); 108 } 109 } 110 }
运行截图:
三、需要按PSP流程进行工作量估算,填写任务清单工作量估算表。
PSP阶段 |
时间估算(小时) |
实际实际(小时) |
|
计划 |
估计每个阶段的时间成本 |
6 |
4 |
开发 |
需求分析 |
0.5 |
0.2 |
系统设计 |
0.3 |
0.1 |
|
设计复审 |
0.2 |
0.1 |
|
代码实现 |
0.6 |
0.6 |
|
代码复审 |
0.2 |
0.1 |
|
测试 |
0.2 |
0.1 |
|
报告 |
测试报告 |
2 |
1 |
总结 |
2 |
1 |
以上是关于软工 任务2的主要内容,如果未能解决你的问题,请参考以下文章