密码学课程设计身份识别.docx

上传人:b****4 文档编号:1465405 上传时间:2022-10-22 格式:DOCX 页数:10 大小:17.50KB
下载 相关 举报
密码学课程设计身份识别.docx_第1页
第1页 / 共10页
密码学课程设计身份识别.docx_第2页
第2页 / 共10页
密码学课程设计身份识别.docx_第3页
第3页 / 共10页
密码学课程设计身份识别.docx_第4页
第4页 / 共10页
密码学课程设计身份识别.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

密码学课程设计身份识别.docx

《密码学课程设计身份识别.docx》由会员分享,可在线阅读,更多相关《密码学课程设计身份识别.docx(10页珍藏版)》请在冰豆网上搜索。

密码学课程设计身份识别.docx

密码学课程设计身份识别

密码学课程设计:

身份识别

身份号码是特征组合码,由十七位数字本体码和一位校验码组成。

排列顺序从左至右依次为:

六位数字地址码,八位数字出生日期码,三位数字顺序码和一位数字校验码。

身份证地址码表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按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;i

intk=(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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 党团工作 > 入党转正申请

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1