密码学课程设计身份识别.docx
《密码学课程设计身份识别.docx》由会员分享,可在线阅读,更多相关《密码学课程设计身份识别.docx(10页珍藏版)》请在冰豆网上搜索。
![密码学课程设计身份识别.docx](https://file1.bdocx.com/fileroot1/2022-10/13/e850e431-7b40-4932-b608-939ff46ea861/e850e431-7b40-4932-b608-939ff46ea8611.gif)
密码学课程设计身份识别
密码学课程设计:
身份识别
身份号码是特征组合码,由十七位数字本体码和一位校验码组成。
排列顺序从左至右依次为:
六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
身份证地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。
身份证出生日期码表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日代码之间不用分隔符。
身份证顺序码表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。
身份证校验码是十七位数字本体码加权求和而得出的。
编码规则:
公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。
排列顺序从左至右依次为:
六位数字地址码,八位数字出生日期码,三位数字顺序码和一位校验码,可以用字母表示如为ABCDEFYYYYMMDDXXXR。
其含义如下:
1.地址码(ABCDEF):
表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。
2.出生日期码(YYYYMMDD):
表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日分别用4位、2位(不足两位加0)、2位(不足两位加0)数字表示,之间不用分隔符。
3.顺序码(XXX):
表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。
4.校验码(R),一位数字,通过前17位数字根据一定计算得出,检验码分别是“0、1、2、……10”共11个数字,当检验码为“10”时,为了保证公民身份证号码18位,所以用“X”表示。
1、关于中国居民身份证的常识:
我国现行使用公民身份证号码有两种尊循两个国家标准,〖GB11643-1989〗和〖GB11643-1999〗。
〖GB11643-1989〗中规定的是15位身份证号码:
排列顺序从左至右依次为:
六位数字地址码,六位数字出生日期码,三位数字顺序码,其中出生日期码不包含世纪数。
〖GB11643-1999〗中规定的是18位身份证号码:
公民身份号码是特征组合码,由十七位数字本体码和一位数字校验码组成。
排列顺序从左至右依次为:
六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。
地址码:
表示编码对象常住户口所在县(市、旗、区)的行政区划代码。
出生日期码:
表示编码对象出生的年、月、日,其中年份用四位数字表示,年、月、日之间不用分隔符。
顺序码:
表示同一地址码所标识的区域范围内,对同年、同月、同日出生的人员编定的顺序号。
顺序码的奇数分给男性,偶数分给女性。
校验码:
是根据前面十七位数字码,按照ISO7064:
1983.MOD11-2校验码计算出来的检验码。
关于身份证号码最后一位的校验码的算法如下:
∑(a[i]*W[i])mod11(i=2,3,...,18)
"*":
表示乘号
i:
表示身份证号码每一位的序号,从右至左,最左侧为18,最右侧为1。
a[i]:
表示身份证号码第i位上的号码
W[i]:
表示第i位上的权值W[i]=2^(i-1)mod11
设:
R=∑(a[i]*W[i])mod11(i=2,3,...,18)
C=身份证号码的校验码
则R和C之间的对应关系如下表:
R:
012345678910
C:
10X98765432
由此看出X就是10,罗马数字中的10就是X,所以在新标准的身份证号码中可能含有非数字的字母X。
算法:
importjava.text.DateFormat;
importjava.text.NumberFormat;
importjava.text.ParseException;
importjava.util.Date;
importjava.util.Random;
/**
*@author成晓旭
*
*/
publicclassIdentity{
//位权值数组
privatestaticbyte[]Wi=newbyte[17];
//身份证前部分字符数
privatestaticfinalbytefPart=6;
//身份证算法求模关键值
privatestaticfinalbytefMod=11;
//旧身份证长度
privatestaticfinalbyteoldIDLen=15;
//新身份证长度
privatestaticfinalbytenewIDLen=18;
//新身份证年份标志
privatestaticfinalStringyearFlag="19";
//校验码串
privatestaticfinalStringCheckCode="10X98765432";
//最小的行政区划码
privatestaticfinalintminCode=150000;
//最大的行政区划码
privatestaticfinalintmaxCode=700000;
//旧身份证号码
//privateStringoldIDCard="";
//新身份证号码
//privateStringnewIDCard="";
//地区及编码
//privateStringArea[][2]=
privatestaticvoidsetWiBuffer(){
for(inti=0;iintk=(int)Math.pow(2,(Wi.length-i));
Wi[i]=(byte)(k%fMod);
}
}
//获取新身份证的最后一位:
检验位
privatestaticStringgetCheckFlag(StringidCard){
intsum=0;
//进行加权求和
for(inti=0;i<17;i++){
sum+=Integer.parseInt(idCard.substring(i,i+1))*Wi[i];
}
//取模运算,得到模值
byteiCode=(byte)(sum%fMod);
returnCheckCode.substring(iCode,iCode+1);
}
//判断串长度的合法性
privatestaticbooleancheckLength(finalStringidCard,booleannewIDFlag){
booleanright=(idCard.length()==oldIDLen)||(idCard.length()==newIDLen);
newIDFlag=false;
if(right){
newIDFlag=(idCard.length()==newIDLen);
}
returnright;
}
//获取时间串
privatestaticStringgetIDDate(finalStringidCard,booleannewIDFlag){
StringdateStr="";
if(newIDFlag)
dateStr=idCard.substring(fPart,fPart+8);
else
dateStr=yearFlag+idCard.substring(fPart,fPart+6);
returndateStr;
}
//判断时间合法性
privatestaticbooleancheckDate(finalStringdateSource){
StringdateStr=dateSource.substring(0,4)+"-"+dateSource.substring(4,6)+"-"+dateSource.substring(6,8);
System.out.println(dateStr);
DateFormatdf=DateFormat.getDateInstance();
df.setLenient(false);
try{
Datedate=df.parse(dateStr);
return(date!
=null);
}catch(ParseExceptione){
//TODOAuto-generatedcatchblock
returnfalse;
}
}
//旧身份证转换成新身份证号码
publicstaticStringgetNewIDCard(finalStringoldIDCard){
//初始化方法
Identity.setWiBuffer();
if(!
checkIDCard(oldIDCard)){
returnoldIDCard;
}
StringnewIDCard=oldIDCard.substring(0,fPart);
newIDCard+=yearFlag;
newIDCard+=oldIDCard.substring(fPart,oldIDCard.length());
Stringch=getCheckFlag(newIDCard);
newIDCard+=ch;
returnnewIDCard;
}
//新身份证转换成旧身份证号码
publicstaticStringgetOldIDCard(finalStringnewIDCard){
//初始化方法
Identity.setWiBuffer();
if(!
checkIDCard(newIDCard)){
returnnewIDCard;
}
StringoldIDCard=newIDCard.substring(0,fPart)+
newIDCard.substring(fPart+yearFlag.length(),newIDCard.length()-1);
returnoldIDCard;
}
//判断身份证号码的合法性
publicstaticbooleancheckIDCard(finalStringidCard){
//初始化方法
Identity.setWiBuffer();
booleanisNew=false;
//Stringmessage="";
if(!
checkLength(idCard,isNew)){
//message="ID长度异常";
returnfalse;
}
StringidDate=getIDDate(idCard,isNew);
if(!
checkDate(idDate)){
//message="ID时间异常";
returnfalse;
}
if(isNew){
StringcheckFlag=getCheckFlag(idCard);
StringtheFlag=idCard.substring