密码学课程设计身份识别Word文档格式.docx
- 文档编号:14380961
- 上传时间:2022-10-22
- 格式:DOCX
- 页数:10
- 大小:17.50KB
密码学课程设计身份识别Word文档格式.docx
《密码学课程设计身份识别Word文档格式.docx》由会员分享,可在线阅读,更多相关《密码学课程设计身份识别Word文档格式.docx(10页珍藏版)》请在冰豆网上搜索。
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<
Wi.length;
i++){
intk=(int)Math.pow(2,(Wi.length-i));
Wi[i]=(byte)(k%fMod);
}
//获取新身份证的最后一位:
检验位
privatestaticStringgetCheckFlag(StringidCard){
intsum=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){
checkIDCard(newIDCard)){
StringoldIDCard=newIDCard.substring(0,fPart)+
newIDCard.substring(fPart+yearFlag.length(),newIDCard.length()-1);
//判断身份证号码的合法性
publicstaticbooleancheckIDCard(finalStringidCard){
booleanisNew=false;
//Stringmessage="
if(!
checkLength(idCard,isNew)){
//message="
ID长度异常"
StringidDate=getIDDate(idCard,isNew);
checkDate(idDate)){
ID时间异常"
if(isNew){
StringcheckFlag=getCheckFlag(idCard);
StringtheFlag=idCard.substring
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 密码学 课程设计 身份 识别