搜档网
当前位置:搜档网 › 身份证验证

身份证验证

身份证验证
身份证验证

彩色影像扫描仪

全国公民身份信息核查比对服务

操作手册

全国公民身份证号码查询服务中心

2010年7月

目录

1功能介绍 (1)

1.1关于彩色影像扫描仪 (1)

1.2关于全国公民身份信息核查比对服务 (1)

1.2.1服务定义 (1)

1.2.2核查比对结果 (2)

2建议配置 (3)

3扫描仪驱动安装 (4)

3.1硬件驱动程序安装 (4)

3.2扫描仪核心软件安装 (4)

4登录系统 (7)

5安装控件 (8)

5.1添加“可信站点” (8)

5.2“可信站点”自定义设置 (9)

5.3选择服务\安装控件 (10)

6扫描并核查比对 (12)

6.1正确放入证件 (12)

6.2选择证件类型 (12)

6.3扫描并核查比对 (13)

6.4反馈核查比对结果 (14)

6.5手工修改 (14)

7客户服务 (16)

8常见问题解答 (17)

8.1系统登录问题 (17)

8.2扫描仪没有响应 (17)

8.3页面错误导致无法提交 (18)

9特别声明 (20)

感谢您使用全国公民身份证号码查询服务中心提供的身份信息核查比对服务,我们将竭诚为您服务。

防范欺诈风险是你我共同的责任。

1功能介绍

1.1 关于彩色影像扫描仪

此彩色影像扫描仪是全国公民身份证号码查询服务中心监制的一款集扫描、识别、录入、核查比对为一体的专用扫描设备。扫描、识别、录入与我们的核查比对服务绑定在一起一键集成,为客户简化手工录入流程,提高工作效率。

1.2 关于全国公民身份信息核查比对服务

1.2.1服务定义

全国公民身份信息核查比对服务是指公民个人在进行社会和经济活动时,向有关机构主动提交身份证件,有关机构工作人员将公民主动提交的身份号码、姓名等信息传送至“全国公民身份信息系统”(以下简称“系统”)进行比对,系统将提供的数据与存储的数据进行比对后,返回被核查人公民身份号码、姓名与系统存储数据是否一致的结果。在核查比对结果为“一致”的前提下,如果系统存有该被核查人照片,则可以进一步比对照片,不提供任何其他信息。

1.2.2核查比对结果

(1)返回核查比对结果显示为身份号码、姓名均“一致”:表示提交的公民身份号码、姓名与系统存储的数据一致,若系统存有被核查人照片,则可以进一步比对照片,此照片仅供参考,如有疑义请到被核查人户籍所在地公安部门进一步核实。

(2)返回核查比对结果显示为身份号码“一致”、姓名“不一致”:表示系统中存有该身份号码,但该身份号码对应的姓名与提交的姓名不一致,这种情况不提供照片比对,建议到被核查人户籍所在地公安部门进一步核实。

(3)返回核查比对结果显示为“库中无此号”:表示系统中没有存储此身份号码,建议到被核查人户籍所在地公安部门进一步核实。

2建议配置

操作系统可支持:Windows 2000\XP\Vista(32位)\Win7(32位) 浏览器可支持:IE6.0-8.0

建议配置:Windows XP + IE6

3扫描仪驱动安装

3.1 硬件驱动程序安装

使用附带光盘安装,具体操作步骤参见<<彩色影像扫描仪-快速安装手册>>。

3.2 扫描仪核心软件安装

把AW110_SCANNER_LIB 文件夹拷贝到C盘根目录下,然后右键点击我的电脑,选择“属性”选项卡,弹出如图3.1所示:

图3.1 属性框

点击“高级 环境变量”弹出如图3.2所示:

图3.2环境变量框

在系统变量中找到变量名为path的一行,如图3.3所示:

图3.3 选中变量名path行

点击“编辑”,在变量值输入框末尾增加括号中的内容:

(;C:\AW110_SCANNER_LIB),如图3.4所示:

图3.4 设置环境变量值

4登录系统

在IE地址栏中输入https://https://www.sodocs.net/doc/4311269347.html,/nciic_self/,进入登录页面。如图4.1所示界面。

图4.1 系统登录界面

在登录页面输入登录帐号、登录密码,并根据提示的数字,输入验证码,点击“登录”按钮。如图4.2所示界面。

图4.2 系统登录界面

5安装控件

第一次使用服务时,需要下载、安装系统控件。这需要对浏览器的“Internet选项”进行必要的设置。下面以IE8.0浏览器为例,介绍一下浏览器的设置方法。点击浏览器上的“工具”标签,选择“Internet 选项”,即可打开需设置的区域。如图5.1所示。

图5.1 打开“Internet选项”

5.1 添加“可信站点”

点击“安全”选项卡,选定“可信站点”,在“将该网站添加到区域”处输入网址https://https://www.sodocs.net/doc/4311269347.html,,点击“添加”按钮,将该网址添加为可信站点,添加完成后点击“关闭”。

注意:在添加之前请确保已经去掉了该页下端“对该区域中的所有站点要求服务器验证(https:) (S)”选项前的“√”。如图5.2所示。

图5.2 添加“可信站点”

5.2 “可信站点”自定义设置

点击“安全”选项卡,选定“可信站点”,再点击“自定义级别”。进入“可信站点”的设置区域。如图5.3所示。

图5. 3 进入“可信站点”设置

向下拖动滚动条,直至找到“ActiveX控件和插件”项,设置其

中“对未标记为可安全执行脚本的ActiveX控件初始化并执行脚本”、“下载未签名的ActiveX控件”两项为“启用”,点击确定。

以上设置完成,请关闭浏览器后再次登录。

5.3 选择服务\安装控件

点击“核心服务”。如图5. 4所示。

图5.4 选择核心服务

在“核心服务”下,点击“扫描核查”,弹出扫描核查窗口。如图5.5所示。

图5.5 选择扫描核查

通常此时可以自动将控件安装成功;如果出现网页上方的拦截工作条,选择“允许安装此控件”,即可安装控件。如图5.6所示。

图5.6 安装系统控件

6扫描并核查比对

6.1 正确放入证件

将身份证的正面(个人信息面)向下,身份证紧贴扫描屏的上边和左边。如图6.1所示。

图6.1 身份证摆放位置

6.2 选择证件类型

确认放置好要扫描的身份证后,回到系统界面,选择要扫描的证件类型。如图6.2所示。

图6.2 选择证件类型

6.3 扫描并核查比对

点击“提交”按钮,扫描、核查一并完成。如图6.3所示。

图6.3 提交扫描并核查比对

6.4 反馈核查比对结果

“提交”后,系统自动显示核查比对结果,可直接打印该结果。如图6.4所示。

图6.4 显示扫描核查比对结果

6.5 手工修改

如果出现识别信息与证件信息不一致的情况,可以通过手工修改识别信息,然后再次提交核查。

在显示核查比对结果页面点击“信息核查”标签,即可跳转显示识别信息和扫描证件原图。如图6.5所示。

图6.5 显示扫描信息

选择“手输”可以修改“公民身份号码”和“姓名”文本框中的信息。点击“提交”按钮,可进行再次核查比对。如图6.6所示。

图6.6 手工修改

7客户服务

如在使用中出现其他问题或存在疑问,请与全国公民身份证号码查询服务中心客服部联系。

单位地址:北京市海淀区首都体育馆南路一号

客服专线:(010)88472909/2917

门户网站:https://www.sodocs.net/doc/4311269347.html, 或https://www.sodocs.net/doc/4311269347.html,

8常见问题解答

8.1 系统登录问题

当提示“用户名不存在”时,请返回输入页面,检查“登录帐号”中用户名是否正确输入,注意区分英文字母的大小写。

当提示“密码不正确”时,请返回输入页面,重新输入正确的登录密码。如果密码中含有英文字母,注意区分英文字母的大小写。密码输入有五次限制机会,超过五次,系统将自动冻结登录帐号,请与我中心客户服务热线联系予以解冻。

当提示“验证码错误”时,请返回输入页面,再次输入验证码重新进行登录(验证码可点击图标以重新获取)。

8.2 扫描仪没有响应

出现“找不到扫描仪”或“目前扫描仪没有在线”等提示导致无法使用时,请按照以下步骤检查扫描功能是否正常:

以WinXP操作系统为例,依次点击“开始→所有程序→Avision AW110 Scanne→Avision Capture Tool”,启动扫描仪。如图8.1所示。

图8.1启动扫描仪

如果无法正常启动,请检查:扫描仪电源指示灯是否为绿色,如没有正常亮起,请检查电源是否接通;扫描仪与电脑的USB连接线

是否正常接通,建议使用USB2.0接口;扫描仪驱动是否按照《快速安装手册》正确安装。正常启动后,使用该扫描程序确保功能正常。

8.3 页面错误导致无法提交

如果页面左下角出现了如图8.2所示的错误提示,导致点击“提交”按钮无反映,请按照以下步骤进行检查:

图8.2 页面错误

首先进入C:\WINDOWS\system32目录下,查看是否控件是否已安装,如图8.3所示。

图8.3 控件安装位置

Excel判断身份证号校验码

Excel判断身份证号校验码 假设在一个工作表中:A列是姓名,B列是身份证号码,C列是备注。在B列中输入18位身份证号码后,在C2单元格中输入计算数组公式: =RIGHT(B2,1)=MID("10X98765432",MOD(SUM(MID(B2,ROW(INDIRECT("1:17")),1)*2^(18-ROW(INDIRECT("1:17")))),11)+1,1) 然后再将该公式复制给C列其他单元格。 公式的计算结果是一个逻辑值,True表示校验正确,即计算出来的校验码与输入的相同,而False则表示校验错误。值得注意的是,使用校验码进行校验判断为正确的身份证号码未必是正确的,但判断为错误的则肯定是错误的,即通过校验的只是身份证号码正确的必要条件而非充分条件。当然,在实际输入中,身份证号码输入错误而校验正确的情况很少见。在大多数情况下,使用校验码进行校验可以大大提高身份证号码输入的正确性。 RIGHT 根据所指定的字符数返回文本字符串中最后一个或多个字符。 MID 返回文本字符串中从指定位置开始的特定数目的字符,该数目由用户指定。 MOD 返回两数相除的余数。SUM 返回某一单元格区域中所有数字之和。ROW 返回引用的行号。INDIRECT 返回由文本字符串指定的引用。 或者输入数组公式: =IF(LEN(B2)<>18,"错误 ",IF(MID("10X98765432",MOD(SUM(MID(B2,ROW(INDIRECT("1:17")),1)*2^(18-ROW(INDIRECT("1:17")))),11)+1,1)=MID(B2,18,1), "正确","错误"))

身份证号码校验实例

身份证号码校验实例 身份证号码是按照一定规律编制的,是个人身份的有效证明,每个人只有一个号码,且不会重复,因而被各单位各部门广泛应用在相关名册中。在大量的身份证号码录入过程中,由于抄写或录入等原因,可能会弄错了某位数字,如果录错了任何一位数字,计算出来的校验码就不一样。根据这一特点,本函数可以对已录入的大批量身份证号码进行校验,如果校验未通过,则说明你录入的号码中必定是某位数字错了,应及时更正,以保证身份证号码正确有效,如果录入的是第一代15位身份证号码,本函数将返回18位号码,使身份证号码保持统一的位数。 代码如下: Function IDcheck(ID) '身份证号码校验函数 Dim s, iAs Integer Dim e, z As String Part1: '----------------------------身份证号码合法性检查--------------------------------------- If Not (Len(ID) = 18 Or Len(ID) = 15) Then '位数检验 IDcheck = "位数错误" Exit Function Else If Len(ID) = 15 Then ID = Left(ID, 6) & "19" & Right(ID, 9)

If IsNumeric(Left(ID, 17)) = False Or InStr(ID, ".") > 0 Then '字符检验 IDcheck = "字符错误" Exit Function End If On Error Resume Next '日期检验 If DateValue(Mid(ID, 7, 4) & "-" & Mid(ID, 11, 2) & "-" & Mid(ID, 13, 2)) < 1 Or _ DateValue(Mid(ID, 7, 4) & "-" & Mid(ID, 11, 2) & "-" & Mid(ID, 13, 2)) > Date Then IDcheck = "日期错误" Exit Function End If End If Part2: '-----------------------------校验码的生成及检查---------------------------------------- s = 0 For i = 1 To 17 s = s + Val(Mid(ID, 18 - i, 1)) * (2 ^ i Mod 11)

身份证号码验证课程设计

目录 1 绪论 (1) 1.1课题内容与要求 (1) 1.2需求分析 (1) 1.3操作环境 (1) 2 功能实现设计 (2) 2.1总体设计 (2) 2.1.1程序设计组成框图 (2) 2.1.2数据流图 (2) 2.2详细设计 (3) 2.2.1存放信息设计 (4) 2.2.2构造函数设计 (4) 2.2.3判断信息是否正确 (9) 2.2.4新旧身份证号转换 (13) 2.2.5窗口类的创建及实现 (13) 3 运行结果 (14) 4 总结 (16) 参考文献 (17) 附录 (18)

1 绪论 1.1 课题内容与要求 课题内容 身份证第18位(校验码)的计算方法: (1)将前面的身份证号码17位分别乘以不同的系数: 从第一位到第十七位的系数分别为: 7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2; (2)将这17位数字和系数相乘的结果相加; (3)用加出来和除以11,得余数; (4)余数0-1-2-3-4-5-6-7-8-9-10 对应的最后一位身份证号码为1-0-X-9-8-7-6-5-4-3-2; 身份证号码的第七位到十四位为出生年月日,应符合现实; 课题要求 (1)使用java语言完成本课题的程序设计,并具有一定的深度和难度; (2)结构化程序设计,源程序要有适当的注释,使程序容易阅读; (3)能先对问题进行分析然后进行设计最后进行编码的原则。每一步都要有文档产生; (4)程序一定要做必要的测试和分析,必须得到合理结果; (5)可适当添加功能,让程序更具有实用性。 (6)提交的所有材料必须符合《长沙理工大学课程设计管理规定》(长理工大[2005]8号)的要求。 1.2 需求分析 本课题主要目的是为了设计一套程序来验证给出的身份证号是否正确,如若正确将身份证号所体现的关键信息性别,年龄,出生日期展现给用户,同时考虑到实实际情况给出了十五位身份证号转十八位,以及十八位转十五位的算法,从而给相关部门机构带来方便。

全国身份证及港澳台身份证验证js代码、函数。

// 988058查号网,骗子号码查询(http:// https://www.sodocs.net/doc/4311269347.html,) //一下是验证身份证号码的js函数 function checkIdcard(idcard){ var Errors=new Array( "验证通过!", "身份证号码位数不对!", "身份证号码出生日期超出范围或含有非法字符!", "身份证号码校验错误!", "身份证地区非法!" ); var area={11:"北京",12:"天津",13:"河北",14:"山西",15:"内蒙古",21:"辽宁",22:"吉林",23:"黑龙江",31:"上海",32:"江苏",33:"浙江",34:"安徽",35:"福建",36:"江西",37:"山东",41:"河南",42:"湖北",43:"湖南",44:"广东",45:"广西",46:"海南",50:"重庆",51:"四川",52:"贵州",53:"云南",54:"西藏",61:"陕西",62:"甘肃",63:"青海",64:"宁夏",65:"新疆",71:"台湾",81:"香港",82:"澳门",91:"国外"} var retflag=false; var idcard,Y,JYM; var S,M; var idcard_array = new Array(); idcard_array = idcard.split(""); //地区检验 if(area[parseInt(idcard.substr(0,2))]==null) return Errors[4]; //身份号码位数及格式检验 switch(idcard.length){ case 15: if ( (parseInt(idcard.substr(6,2))+1900) % 4 == 0 || ((parseInt(idcard.substr(6,2))+1900) % 100 == 0 && (parseInt(idcard.substr(6,2))+1900) % 4 == 0 )){ ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9] |[1-2][0-9]|30)|02(0[1-9]|[1-2][0-9]))[0-9]{3}$/;//测试出生日期的合法性 } else { ereg=/^[1-9][0-9]{5}[0-9]{2}((01|03|05|07|08|10|12)(0[1-9]|[1-2][0-9]|3[0-1])|(04|06|09|11)(0[1-9] |[1-2][0-9]|30)|02(0[1-9]|1[0-9]|2[0-8]))[0-9]{3}$/;//测试出生日期的合法性 } if(ereg.test(idcard)) return Errors[0]; else { return Errors[2]; } break; case 18: //18位身份号码检测 //出生日期的合法性检查

中华人民共和国身份证号码规则

18位身份证标准在国家质量技术监督局于1999年7月1日实施的GB11643-1999《公民身份号码》中做了明确规定。GB11643-1999《公民身份号码》为GB11643-1989《社会保障号码》的修订版,其中指出将原标准名称“社会保障号码”更名为“公民身份号码”,另外GB11643-1999《公民身份号码》从实施之日起代替GB11643-1989。 公民身份号码是特征组合码,由十七位数字本体码和一位校验码组成。排列顺序从左至右依次为:六位数字地址码,八位数字出生日期码,三位数字顺序码和一位校验码。其含义如下: 1. 地址码:表示编码对象常住户口所在县(市、旗、区)的行政区划代码,按GB/T2260的规定执行。 2. 出生日期码:表示编码对象出生的年、月、日,按GB/T7408的规定执行,年、月、日分别用4位、2位、2位数字表示,之间不用分隔符。 3. 顺序码:表示在同一地址码所标识的区域范围内,对同年、同月、同日出生的人编定的顺序号,顺序码的奇数分配给男性,偶数分配给女性。 校验的计算方式: 1. 对前17位数字本体码加权求和 公式为:S = Sum(Ai * Wi), i = 0, ... , 16 其中Ai表示第i位置上的身份证号码数字值,Wi表示第i位置上的加权因子,其各位对应的值依次为:7 9 10 5 8 4 2 1 6 3 7 9 10 5 8 4 2 2. 以11对计算结果取模 Y = mod(S, 11) 3. 根据模的值得到对应的校验码 对应关系为: Y值:0 1 2 3 4 5 6 7 8 9 10 校验码: 1 0 X 9 8 7 6 5 4 3 2 身份证号码的编排规则 身份证号码中这些数字是怎样排列的,每个数字表示什么意思呢?下面就让我们一起来探索其中的规律吧!新的身份证号码是由18位数字组成的,它们分别表示: (1)前1、2位数字表示:所在省份的代码; (2)第3、4位数字表示:所在城市的代码; (3)第5、6位数字表示:所在区县的代码; (4)第7~14位数字表示:出生年、月、日; (5)第15、16位数字表示:所在地的派出所的代码; (6)第17位数字表示性别:奇数表示男性,偶数表示女性; (7)第18位数字是校检码:也有的说是个人信息码,一般是随计算机的随机产生, 用来检验身份证的正确性。校检码可以是0~9的数字,有时也用x表示。 15位的身份证号 dddddd yymmdd xx p 18位的身份证号 dddddd yyyymmdd xx p y 其中dddddd为地址码(省地县三级)18位中的和15位中的不完全相同 yyyymmdd yymmdd 为出生年月日 xx顺号类编码 p性别 18位中末尾的y为校验码,在网上可以找到算法 将前17位的ascii码值经位移、异或运算结果不在0-9的令其为x 中华人民共和国行政区划代码(GB/T2260—999) 代码省、市名称代码省、市名称 11 北京市 42 湖北省

检验身份证号码的正确性

检验身份证号码的正确性 =IF(LEN(A2)=18,MID("10X98765432",MOD(SUMPRODUCT(MID(A2,ROW(INDIRECT("1:1 7")),1)*2^(18-ROW(INDIRECT("1:17")))),11)+1,1)=RIGHT(A2),IF(LEN(A2)=15,ISNUMBER(--TEXT(19&MID(A2,7,6),"#-00-00")))) EXCEL中如何提取身份证出生日期、性别、检验身份证号码的正确性 中国居民身份证号码是一组特征组合码,原为15位,现升级为18位,其编码规则为:15位:6位数字常住户口所在县市的行政区划代码,6位数字出生日期代码,3位数字顺序码。 18位:6位数字常住户口所在县市的行政区划代码,8位数字出生日期代码,3位数字顺序码和1位检验码。 其中3位数字顺序码,是为同一地址码的同年同月同日出生人员编制的顺序号,偶数的为女性,奇数的为男性。 1、提取籍贯地区的行政区划代码(A2为身份证号,下同) 15与18位通用:=LEFT(A2,6) 如果有一个编码和省份地区的对照表,可以用VLOOKUP函数来提取地区信息。 2、提取出生日期信息 15位:=--TEXT(19&MID(A2,7,6),"#-00-00") 18位:=--TEXT(MID(A2,7,8),"#-00-00") 15与18位通用: =--TEXT(IF(LEN(A2)=15,19,"")&MID(A2,7,6+IF(LEN(A2)=18,2,0)),"#-00-00") 简化公式: =--TEXT((LEN(A2)=15)*19&MID(A2,7,6+(LEN(A2)=18)*2),"#-00-00") (请将输入公式的单元格格式设置为日期格式) 3、提取性别信息 15位:=IF(MOD(RIGHT(A2),2)=1,"男","女") 18位:=IF(MOD(MID(A2),17,1)=1,"男","女") 15与18位通用:=IF(MOD(MID(A2,IF(LEN(A2)=15,15,17),1),2)=1,"男","女") 简化公式:=IF(MOD(RIGHT(LEFT(A2,17)),2),"男","女") 4、检验身份证号码的正确性 18位身份证号码的最后一位是检验码,它是根据身份证前17位数字依照规则计算出来的,其值0~9或X。一般情况只要有一位数字输入错误,依照规则计算后就会与第18位数不符。当然不排除按错误号码计算后恰好与检验码相符的情况,但这种情况出现的可能性较低。因此,对18位号码的验证采用如下公式: =MID("10X98765432",MOD(SUMPRODUCT(MID(A2,ROW(INDIRECT("1:17")),1)*2^(18-R OW(INDIRECT("1:17")))),11)+1,1)=RIGHT(A2,1) 对于15位身份证,由于没有检验码,我们只能简单地去判断出生日期代码是否是一个有效的日期,避免输入一些像“731302”或“980230“等这样不存在的日期。

身份证校验码的解释

身份证校验码的解释 新居民身份证的号码是按照国家的标准编制的,由18位组成:前六位为行政区划代码,第七至第十四位为出生日期码,第15至17位为顺序码,第18位为校验码。作为尾号的校验码,是由号码编制单位按统一的公式计算出来的,如果某人的尾号是0-9,都不会出现X,但如果尾号是10,那么就得用X来代替,因为如果用10做尾号,那么此人的身份证就变成了19位,而19位的号码违反了国家标准,并且我国的计算机应用系统也不承认19位的身份证号码。Ⅹ是罗马数字的10,用X来代替10,可以保证公民的身份证符合国家标准。 身份证中第十八位数字的计算方法为: 1.将前面的身份证号码17位数分别乘以不同的系数。从第一位到第十七位的系数分别为:7、9、10、5、8、4、2、1、6、3、7、9、10、5、8、4、2。 2.将这17位数字和系数相乘的结果相加。 3.用加出来和除以11,看余数是多少? 4余数只可能有0 、1、2、3、4、5、6、7、8、9、10这11个数字。其分别对应的最后一位身份证的号码为1、0、X、9、8、7、6、5、4、3、2。 5.通过上面得知如果余数是2,就会在身份证的第18位数字上出现罗马数字的Ⅹ。如果余数是10,身份证的最后一位号码就是2。 例如:某男性的身份证号码是340524************。我们要看看这个身份证是不是合法的身份证。 首先:我们得出,前17位的乘积和是189 然后:用189除以11得出的结果是17 + 2/11,也就是说余数是2。 最后:通过对应规则就可以知道余数2对应的数字是x。所以,这是一个合格的身份证号码。

这里面说的很清楚了,最后一位是用来辨别身份证真假的一种办法。而不是同年同月同日生的人的识别码。 贴个JA V A实现的校验算法 public static char doV erify(String id); { char pszSrc[]=id.toCharArray();; int iS = 0; int iW[]={7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2}; char szVerCode[] = new char[]{'1','0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'}; int i; for(i=0;i<17;i++); { iS += (int);(pszSrc-'0'); * iW; } int iY = iS%11; return szVerCode[iY]; } =IF(LEN(A101)=15,REPLACE(A101,7,,19)&MID("10X98765432",MOD(SUM(MID(REPLAC E(A101,7,,19),ROW(INDIRECT("1:17")),1)*2^(18-ROW(INDIRECT("1:17")))),11)+1,1),A101 excel计算最后一位的公式,也就是个校验码而已

net实现中国身份证号码验证源码

.net实现中国身份证号码验证源码 using System; /// /// Summary descr ip tion for IDCardValid /// public cl as s IDCardValid { public IDCardValid() { // // TODO: Add constructor logic here // } /// /// 验证身份证号码 /// /// 身份证号码 /// 验证成功为True,否则为False public static bool CheckIDCard(string Id) { if (Id.Length == 18) { bool check = CheckIDCard18(Id); return check; } else if (Id.Length == 15) { bool check = CheckIDCard15(Id); return check; } else { return false; } } #region 身份证号码验证 /// /// 验证15位身份证号 /// /// 身份证号 /// 验证成功为True,否则为False private static bool CheckIDCard18(string Id) { long n = 0; if (long.TryParse(Id.Remove(17), out n) == false || n < Math.Pow(10, 16) || long.TryParse(Id.Replace('x', '0').Replace('X', '0'), out n) == false) { return false;//数字验证 } string address = "11x22x35x44x53x12x23x36x45x54x13x31x37x46x6 1x14x32x41x50x62x15x33x42x51x63x21x34x43x52 x64x65x71x81x82x91"; if (address.IndexOf(Id.Remove(2)) == -1) { return false;//省份验证 } string birth = Id.Substring(6, 8).Insert (6, "-").Insert(4, "-"); DateTime time = new DateTime(); if (DateTime.TryParse(birth, out time) == false) { return false;//生日验证 } string[] arrVarifyCode = ("1,0,x,9,8,7,6,5,4,3,2").Split(','); string[] Wi = ("7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2").Split(','); char[] Ai = Id.Remove(17).ToCharArray(); int sum = 0; for (int i = 0; i < 17; i++) { sum += int.Parse(Wi[i]) * int.Parse(Ai[i].ToString()); } int y = -1; Math.DivRem(sum, 11, out y); if (arrVarifyCode[y] != Id.Substring(17, 1).ToLower()) { return false;//校验码验证 } return true;//符合GB11643-1999标准 } /// /// 验证18位身份证号 /// /// 身份证号 /// 验证成功为True,否则为False private static bool CheckIDCard15(string Id) { long n = 0; if (long.TryParse(Id, out n) == false || n < 1

身份证验证

彩色影像扫描仪 全国公民身份信息核查比对服务 操作手册 全国公民身份证号码查询服务中心 2010年7月

目录 1功能介绍 (1) 1.1关于彩色影像扫描仪 (1) 1.2关于全国公民身份信息核查比对服务 (1) 1.2.1服务定义 (1) 1.2.2核查比对结果 (2) 2建议配置 (3) 3扫描仪驱动安装 (4) 3.1硬件驱动程序安装 (4) 3.2扫描仪核心软件安装 (4) 4登录系统 (7) 5安装控件 (8) 5.1添加“可信站点” (8) 5.2“可信站点”自定义设置 (9) 5.3选择服务\安装控件 (10) 6扫描并核查比对 (12) 6.1正确放入证件 (12) 6.2选择证件类型 (12) 6.3扫描并核查比对 (13) 6.4反馈核查比对结果 (14) 6.5手工修改 (14) 7客户服务 (16) 8常见问题解答 (17) 8.1系统登录问题 (17) 8.2扫描仪没有响应 (17) 8.3页面错误导致无法提交 (18) 9特别声明 (20)

感谢您使用全国公民身份证号码查询服务中心提供的身份信息核查比对服务,我们将竭诚为您服务。 防范欺诈风险是你我共同的责任。 1功能介绍 1.1 关于彩色影像扫描仪 此彩色影像扫描仪是全国公民身份证号码查询服务中心监制的一款集扫描、识别、录入、核查比对为一体的专用扫描设备。扫描、识别、录入与我们的核查比对服务绑定在一起一键集成,为客户简化手工录入流程,提高工作效率。 1.2 关于全国公民身份信息核查比对服务 1.2.1服务定义 全国公民身份信息核查比对服务是指公民个人在进行社会和经济活动时,向有关机构主动提交身份证件,有关机构工作人员将公民主动提交的身份号码、姓名等信息传送至“全国公民身份信息系统”(以下简称“系统”)进行比对,系统将提供的数据与存储的数据进行比对后,返回被核查人公民身份号码、姓名与系统存储数据是否一致的结果。在核查比对结果为“一致”的前提下,如果系统存有该被核查人照片,则可以进一步比对照片,不提供任何其他信息。

如何用Excel验证身份证号码是否符合规则

EXCEL中如何提取身份证出生日期、性别、检验身份证号 码的正确性 中国居民身份证号码是一组特征组合码,原为15位,现升级为18位,其编码规则为:15位:6位数字常住户口所在县市的行政区划代码,6位数字出生日期代码,3位数字顺序码。 18位:6位数字常住户口所在县市的行政区划代码,8位数字出生日期代码,3位数字顺序码和1位检验码。 其中3位数字顺序码,是为同一地址码的同年同月同日出生人员编制的顺序号,偶数的为女性,奇数的为男性。 1、提取籍贯地区的行政区划代码(A2为身份证号,下同) 15与18位通用:=LEFT(A2,6) 如果有一个编码和省份地区的对照表,可以用VLOOKUP函数来提取地区信息。 2、提取出生日期信息 15位:=--TEXT(19&MID(A2,7,6),"#-00-00") 18位:=--TEXT(MID(A2,7,8),"#-00-00") 15与18位通用:=--TEXT(IF(LEN(A2)=15,19,"")&MID(A2,7,6+IF(LEN(A2)=18,2,0)),"#-00-00") 简化公式:=--TEXT((LEN(A2)=15)*19&MID(A2,7,6+(LEN(A2)=18)*2),"#-00-00") (请将输入公式的单元格格式设置为日期格式) 3、提取性别信息 15位:=IF(MOD(RIGHT(A2),2)=1,"男","女") 18位:=IF(MOD(MID(A2),17,1)=1,"男","女") 15与18位通用:=IF(MOD(MID(A2,IF(LEN(A2)=15,15,17),1),2)=1,"男","女") 简化公式:=IF(MOD(RIGHT(LEFT(A2,17)),2),"男","女") 4、检验身份证号码的正确性 18位身份证号码的最后一位是检验码,它是根据身份证前17位数字依照规则计算出来的,其值0~9或X。一般情况只要有一位数字输入错误,依照规则计算后就会与第18位数不符。当然不排除按错误号码计算后恰好与检验码相符的情况,但这种情况出现的可能性较低。因此,对18位号码的验证采用如下公式: =MID("10X98765432",MOD(SUMPRODUCT(MID(A2,ROW(INDIRECT("1:17")),1)*2^(18-R OW(INDIRECT("1:17")))),11)+1,1)=RIGHT(A2,1) 对于15位身份证,由于没有检验码,我们只能简单地去判断出生日期代码是否是一个有效的日期,避免输入一些像“731302”或“980230“等这样不存在的日期。 =ISNUMBER(--TEXT(19&MID(A2,7,6),"#-00-00")) 综合15位和18位后的通用公式为: =IF(LEN(A2)=18,MID("10X98765432",MOD(SUMPRODUCT(MID(A2,ROW(INDIRECT("1:1 7")),1)*2^(18-ROW(INDIRECT("1:17")))),11)+1,1)=RIGHT(A2),IF(LEN(A2)=15,ISNUMBER(--TEXT(19&MID(A2,7,6),"#-00-00")))) 由于目前15位身份证号码已经很少了,如果对15位的号码不需要作进一步的判断,则公式可以简化成:

EXcel_VBA身份证号码验证

'身份证号码验证 Public Function identi_check(identitynum As String) '身份证号码验证 Dim jyw As Long identi = Replace(identitynum, " ", "") If (Len(identi) > 0 And Len(identi) < 15) Or Len(identi) > 18 Then identi = "不正确,非15、18位" ElseIf Len(identi) = 0 Then identi = "不正确,为空" ElseIf Len(identi) = 15 Then j = 0 For i = 1 To 15 If Not Mid(identi, i, 1) Like "[0-9]" Then j = j + 1 End If Next i If j > 0 Then identi = "不正确,包含非数字" ElseIf Val(Mid(identi, 9, 2)) > 12 Then identi = "不正确,月份大于12" ElseIf Val(Mid(identi, 11, 2)) > 31 Then identi = "不正确,日期大于31" 'MsgBox identi Else identi = "" End If ElseIf Len(identi) = 18 Then 'For i = 1 To 17 jyw = (Mid(identi, 1, 1) * 7 + Mid(identi, 2, 1) * 9 + Mid(identi, 3, 1) * 10 _ + Mid(identi, 4, 1) * 5 + Mid(identi, 5, 1) * 8 + Mid(identi, 6, 1) * 4 _ + Mid(identi, 7, 1) * 2 + Mid(identi, 8, 1) * 1 + Mid(identi, 9, 1) * 6 + Mid(identi, 10, 1) * 3 _ + Mid(identi, 11, 1) * 7 + Mid(identi, 12, 1) * 9 + Mid(identi, 13, 1) * 10 + Mid(identi, 14, 1) * 5 _ + Mid(identi, 15, 1) * 8 + Mid(identi, 16, 1) * 4 + Mid(identi, 17, 1) * 2) jyw = jyw Mod 11 yzm = Replace("1 0 X 9 8 7 6 5 4 3 2", " ", "") If Mid(yzm, jyw + 1, 1) <> Mid(identi, 18, 1) Then identi = "不正确" Else identi = "" End If '7 9 10 5 8 4 '2 1 6 3 7 9 10 5 '8 4 2

身份证号码校验

Visual C++范例开发大全目录Mylaf 2012-10-23 第1篇VC++入门与基本文档视图 第1章Visual C++ 6.0 MFC程序设计快速入门 2 1.1 Visual C++ 6.0开发环境简介2 1.2 创建Visual C++ 6.0应用程序3 实例001 创建第一个MFC应用程序 3 实例002 创建第一个C++应用程序 4 第2章文档视图应用程序实例6 2.1 窗体操作6 实例003 实现启动时无子窗口的MDI程序 6 实例004 实现MDI应用程序启动时子窗口默认最大化7 实例005 MDI应用程序启动时主窗口默认最大化8 实例006 具有图片背景的MDI主窗口9 实例007 全屏显示的窗体12 实例008 创建带滚动条的窗体15 实例009 窗体拆分16 实例010 始终置顶的SDI程序17 实例011 不可移动的窗体18 实例012 创建不可改变大小的SDI窗口19 实例013 动态设置窗口位置和大小20 实例014 保存窗口状态21 实例015 双击主窗口弹出“打开”对话框23 2.2 标题栏25 实例016 获取标题栏高度25 实例017 获取标题栏上按钮的尺寸26 实例018 定制标题栏文字27 实例019 添加标题栏右键菜单项28 实例020 屏蔽标题栏右键系统菜单及隐藏按钮29 实例021 禁用标题栏上的最大化、最小化和关闭按钮30 实例022 显示和隐藏标题栏31 2.3 菜单32 实例023 获取菜单栏高度32 实例024 启用和禁用菜单33 实例025 动态添加菜单35 实例026 带单选标记的菜单36 实例027 复选标记的菜单38 实例028 带图标菜单的SDI程序39 实例029 带图标菜单的MDI 40 实例030 位图菜单41 实例031 创建客户区右键菜单43 实例032 隐藏和显示菜单栏44 实例033 为应用程序添加多语言支持45 2.4 工具栏48 实例034 工具栏按钮的添加、删除和分组48 实例035 不能停靠的工具栏48 实例036 下压式工具栏按钮49 实例037 给工具栏添加图像背景50 实例038 动态隐藏和显示工具栏51 2.5 状态栏52 实例039 显示和隐藏状态栏52 实例040 带进度条的状态栏53 实例041 在状态栏上加载图像54 实例042 滚动字幕的状态栏56 第3章对话框应用实例58 3.1 对话框界面58 实例043 设置对话框应用程序窗口启动位置58 实例044 半透明对话框59 实例045 创建不规则对话框应用程序60 实例046 拖动没有标题栏的对话框61 实例047 实现收缩对话框应用程序62 实例048 基于对话框的托盘程序64 实例049 为对话框应用程序添加菜单栏66 实例050 带有工具栏的对话框应用程序67 实例051 为对话框应用程序添加右键菜单68 实例052 模式对话框与非模式对话框69 实例053 属性页对话框71 实例054 向导式对话框72 实例055 为对话框应用程序添加启动界面73 实例056 为对话框应用程序添加百叶窗的启动界面76 3.2 通用对话框77 实例057 文件打开对话框78 实例058 在程序启动时弹出文件打开对话框79 实例059 在文件打开对话框中预览图片80 实例060 文件保存对话框81 实例061 选择文件夹对话框82 实例062 字体对话框84 实例063 颜色对话框86 实例064 查找与替换对话框87 第4章控件应用实例89 4.1 常见控件89 实例065 图文按钮89 实例066 具有随机图片背景的EditBox控件90 实例067 使用List Box显示系统逻辑磁盘驱动器列表92 实例068 利用列标题对列表视图进行数据排序93 实例069 使用Static Text控件显示当前系统时间95 实例070 使用Data Time Picker控件调整系统时间96 实例071 使用Combo Box控件控制字体大小97 实例072 使用Rich Edit控件显示文本文件98 实例073 使用Tree Control控件显示文件目录100 实例074 位图进度条102 实例075 使用Progress控件实现文字进度条103 实例076 使用Static Text控件显示当前时间104 实例077 使用Picture Box显示动态打开图像106 实例078 使用Group Box控件对控件分组107 实例079 使用Check Box实现多选109 实例080 使用Radio Button实现单选110 实例081 HorizontalScrollBar,VerticalScrollBar滚动条111

第二代居民身份证验证系统技术方案

浙江省全程电子化平台升级改造 —第二代居民身份证验证系统项目方案 一、项目概述 随着市场主体经济户口基数庞大,每天来注册登记办事窗口办理各项业务的络绎不绝,窗口服务人员每天都需要受理大量的各类资格证明、新设立、变更营业执照等各项业务工作,办理人员的信息录入工作量十分巨大,同时在输入办理人员身份证信息过程中,及其可能出现错误,而对办理人员身份信息的可信度和身份证真伪上,又难于验证。导致在办理业务时进度非常缓慢,若是赶上业务高峰期,每个窗口前都挤满了人,办理人员经常为排队的问题而争吵,有时候还会丢失东西。这样不但给来办事的人员带来了不便,也给注册登记窗口服务形象大打折扣。因此,引入第二代居民身份证验证应用显得十分重要和紧迫。 二、项目建设目标 通过二代身份证验证应用的接入,与浙江省全程电子化登记平台相应模块整合,实现办事人员信息快速录入和身份信息真伪准确识别,提升服务质量。 1、能及时准确验证身份信息,有效提升注册窗口工作行政效能。 2、可以降低身份证输入过程中的差错率,提高系统录入正确率。 3、快速鉴别身份证真伪,增强办理人的可信度。 三、系统功能需求 在浙江省全程电子化登记平台内网审核端中嵌入二代身份证验证接口程序,在行政审批科服务窗口和分大厅服务窗口的PC机接入第二代居民身份证验证设

备,再通过登入浙江省全程电子化登记平台内网审核端并确认二代身份证验证设备都已正确连接后,在名称登记受理、设立受理、变更受理等工作中需要录入办事人员姓名、身份证号、住址信息时都可以通过操作“身份证导入”读取办理人的身份信息,于此同时也验证了办事人员身份证真伪,增强办理人的可信度。 a)名称登记受理 窗口在进行名称登记受理时,当投资人为自然人时,可以通过“身份证导入”功能,调用第二代居民身份证验证设备进行第二代居民身份证相关信息读取,并自动填入到投资人信息框中。 b)设立受理 窗口在设立受理时,法定代表人、投资人、董事、监事或经理、代理人等为自然人时,同样可以通过“身份证导入”功能,调用第二代居民身份证验证设备进行第二代居民身份证相关信息读取,并自动填入到投资人信息框中,保证了身份信息的真伪和减少人员信息录入时的错误。

身份证正确检验及验证公式

验证公式一 =IF(LEN(H20)=18,IF(RIGHT(H20,1)="X",IF(CHOOSE(MOD(SUM(LEFT(RIGHT(H20,18) )*7 LEFT(RIGHT(H20,17))*9 LEFT(RIGHT(H20,16))*10 LEFT(RIGHT(H20,15))*5 LEFT(RIGHT(H20,14))*8 LEFT(RIGHT(H20,13))*4 LEFT(RIGHT(H20,12))*2 LEFT(RIGHT(H20,11))*1 LEFT(RIGHT(H20,10))*6 LEFT(RIGHT(H20,9))*3 LEFT(RIGHT(H20,8))*7 LEFT(RIGHT(H20,7))*9 LEFT(RIGHT(H20,6))*10 LEFT(RIGHT(H20,5))*5 LEFT(RIGHT(H20,4))*8 LEFT(RIGHT(H20,3))*4 LEFT(RIGHT(H20,2))*2),11) 1,1,0,"X",9,8,7,6,5,4,3,2)=LEFT(RIGHT(H20,1)),"正确!","出错啦! "),IF(CHOOSE(MOD(SUM(LEFT(RIGHT(H20,18))*7 LEFT(RIGHT(H20,17))*9 LEFT(RIGHT(H20,16))*10 LEFT(RIGHT(H20,15))*5 LEFT(RIGHT(H20,14))*8 LEFT(RIGHT(H20,13))*4 LEFT(RIGHT(H20,12))*2 LEFT(RIGHT(H20,11))*1 LEFT(RIGHT(H20,10))*6 LEFT(RIGHT(H20,9))*3 LEFT(RIGHT(H20,8))*7 LEFT(RIGHT(H20,7))*9 LEFT(RIGHT(H20,6))*10 LEFT(RIGHT(H20,5))*5 LEFT(RIGHT(H20,4))*8 LEFT(RIGHT(H20,3))*4 LEFT(RIGHT(H20,2))*2),11) 1,1,0,"X",9,8,7,6,5,4,3,2)=LEFT(RIGHT(H20,1))*1,"正确!","出错啦!")),IF(LEN(H20)=15,"老号,请注意!",IF(LEN(H20)=0,"缺号码","位数不对!"))) 验证公式二 =MID("10X98765432",MOD(SUMPRODUCT(MID(H20,ROW(INDIRECT("1:17")),1)*2^(18 -ROW(INDIRECT("1:17")))),11) 1,1)=RIGHT(H20,1) 身份证有15位和18位两种,身份证位数是否正确,我们可以用LEN函数判断。但身份证上的日期是否合法:月份是否在1-12之间,日期是否在1-31之间,并且2月份只有28或29天,其他月份30或31天,都不能超过范围。另外一般规定6岁以上才可以办理身份证,也就是年份也有一个超范围的可能性。综合起来看,有三类错误:“身份证位数不对”、“月日错误”、“年份错误”。 假定身份证号码在B1单元格,下面的公式可以综合判断以上三种错误: 验证公式三 =IF(OR(LEN(B1)=18,LEN(B1)=15),IF(LEN(B1)=18,IF(OR(MONTH(DATE(1*(MID(B1,7 ,4)),1*(MID(B1,11,2)),1*(MID(B1,13,2))))<>1*(MID(B1,11,2)),DAY(DATE(1*(M ID(B1,7,4)),1*(MID(B1,11,2)),1*(MID(B1,13,2))))<>1*(MID(B1,13,2))),"月日错误",""),IF(LEN(B1)=15,IF(OR(MONTH(DATE(1*(MID(B1,7,2)) 1900,1*(MID(B1,9,2)),1*(MID(B1,11,2))))<>1*(MID(B1,9,2)),DAY(DATE(1*(MID (B1,7,2)) 1900,1*(MID(B1,9,2)),1*(MID(B1,11,2))))<>1*(MID(B1,11,2))),"月

18位身份证号码验证算法

‘算法为Excel表中用VBA实现身份证号码验证。只验证身份证号码正确否,不验证是否存在此身份证号码。算法思想可普遍适用其他地方。 Sub 身份证号码验证算法() Dim sfzArray(1 To 18) As Integer ‘身份证号码数组,数组每个元素记录每一位号码 Dim sfzPointer As Integer’身份证位数指针,指向每一位号码 Dim checkStart As Long’需验证的起始位置,Excel中第一个身份证号码行号 Dim checkEnd As Long’需验证的最后位置,Excel中最后一个身份证号码行号 Dim checkPointer As Long’验证指针,指向验证的位置 Dim sfzSum As Integer’身份证位数求和 Dim checkWord As String’校验位 Dim initialV alue As String’Excel表中身份证号码初始值 checkStart=2’根据实际情况修改 checkEnd=50000’根据实际情况修改 For checkPointer= checkStart To checkEnd initialV alue = CStr(Cells(checkPointer, 1))’默认Excel表第一列是身份证号码,根据实际情况修改 sfzSum = 0’初始化 For sfzPointer = 1 To 17 sfzArray(sfzPointer) = CInt(Mid(initialV alue, sfzPointer, 1))’对应位赋值给身份证号码数组 Select Case sfzPointer’根据位数不同,求和 Case 1, 11 sfzSum = sfzSum + sfzArray (sfzPointer) * 7 Case 2, 12 sfzSum = sfzSum + sfzArray (sfzPointer)* 9 Case 3, 13 sfzSum = sfzSum + sfzArray (sfzPointer) * 10 Case 4, 14 sfzSum = sfzSum + sfzArray (sfzPointer) * 5 Case 5, 15 sfzSum = sfzSum + sfzArray (sfzPointer)* 8 Case 6, 16 sfzSum = sfzSum + sfzArray (sfzPointer) * 4 Case 7, 17 sfzSum = sfzSum + sfzArray (sfzPointer) * 2 Case 8 sfzSum = sfzSum + sfzArray (sfzPointer) * 1 Case 9 sfzSum = sfzSum + sfzArray (sfzPointer) * 6 Case 10 sfzSum = sfzSum + sfzArray (sfzPointer) * 3 End Select Next sfzPointer sfzSum = sfzSum Mod 11 Select Case sfzS um’根据求模后的余数,可得校验位 Case 0 checkWord = 1 Case 1 checkWord = 0 Case 2 checkWord = "X" Case 3 checkWord = 9 Case 4 checkWord = 8

相关主题