摘要:以上直接上代码验证通过校验不通过号码规则校验身份证号码不合规区位码校验出生年月日校验前正则限制起始年份为身份证年身份证月身份证日身份证日期时间戳当前时间戳身份证当月天数出生日期不合规校验码判断系数校验码对照表身份证校验码不合规校验通过
注意:
1、只针对18为身份证号码进行校验,现在15位的应该很少了,
2、不区分xX大小写,
3、出生年份1900-2099,每月的天数也进行相关验证(考虑的闰月的情况),
4、校验规则详见,这个写的比较详细和清楚,相信看过后都可以自己写一个,
https://jingyan.baidu.com/art...
5、目前还无法对区位码就进行精确校验,本人搜集整理了区位码,提供了一个查询api,仅攻参考。
有不精确的地方可以留言指出
api地址:http://www.xuzee.com/api/idca...
接口说明:http://www.xuzee.com/api/
6、这个验证函数目前在项目中实际运行,暂未发现问题,有问题会进行更新。
以上
直接上代码:
function testid(id) { // 1 "验证通过!", 0 //校验不通过 var format = /^(([1][1-5])|([2][1-3])|([3][1-7])|([4][1-6])|([5][0-4])|([6][1-5])|([7][1])|([8][1-2]))d{4}(([1][9]d{2})|([2]d{3}))(([0][1-9])|([1][0-2]))(([0][1-9])|([1-2][0-9])|([3][0-1]))d{3}[0-9xX]$/; //号码规则校验 if(!format.test(id)){ return {"status":0,"msg":"身份证号码不合规"}; } //区位码校验 //出生年月日校验 前正则限制起始年份为1900; var year = id.substr(6,4),//身份证年 month = id.substr(10,2),//身份证月 date = id.substr(12,2),//身份证日 time = Date.parse(month+"-"+date+"-"+year),//身份证日期时间戳date now_time = Date.parse(new Date()),//当前时间戳 dates = (new Date(year,month,0)).getDate();//身份证当月天数 if(time>now_time||date>dates){ return {"status":0,"msg":"出生日期不合规"} } //校验码判断 var c = new Array(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2); //系数 var b = new Array("1","0","X","9","8","7","6","5","4","3","2"); //校验码对照表 var id_array = id.split(""); var sum = 0; for(var k=0;k<17;k++){ sum+=parseInt(id_array[k])*parseInt(c[k]); } if(id_array[17].toUpperCase() != b[sum%11].toUpperCase()){ return {"status":0,"msg":"身份证校验码不合规"} } return {"status":1,"msg":"校验通过"} }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/84570.html
摘要:功能描述录入一些客户的信息,证件验证,例如身份证护照验证等。身份证号码验证正确以后,手动录入后实现能自动显示生日性别信息,不用手动填写。 功能描述 录入一些客户的信息,证件验证,例如身份证、护照验证等。身份证号码验证正确以后,手动录入后实现能自动显示生日、性别 信息,不用手动填写。 身份证号码组合方式 中华人民共和国公民身份号码 --维基百科,自由的百科全书showImg(https...
摘要:功能描述录入一些客户的信息,证件验证,例如身份证护照验证等。身份证号码验证正确以后,手动录入后实现能自动显示生日性别信息,不用手动填写。 功能描述 录入一些客户的信息,证件验证,例如身份证、护照验证等。身份证号码验证正确以后,手动录入后实现能自动显示生日、性别 信息,不用手动填写。 身份证号码组合方式 中华人民共和国公民身份号码 --维基百科,自由的百科全书showImg(https...
摘要:登录注册安全风险登录注册的风险点主要有四个暴力破解撞库遍历注册用户批量注册。引入了验证码机制同样引入了额外的安全风险,比如短信验证码的短信炸弹风险图形验证码的可绕过可识别等。 概述 很多技术研发不了解安全,也不重视安全,只有在自己的服务器被黑掉、被挂马、被脱裤才想起关注安全,但是这个时候,技术架构已经成型、代码已经在线上稳定运行,再亡羊补牢,改代码、改策略,往往成本巨大、确收效很低。所...
摘要:对于这个页面,如果微信用户没有系统角色,则跳转到登录页。令人忧桑的是,微信小程序并没有提供针对实例的中间件机制。即使用户身份校验不通过,小程序也并不会阻塞页面的渲染。 场景 小程序有52个页面,其中13个页面无需任何身份,另外39个页面需要系统角色。对于这39个页面,如果微信用户没有系统角色,则跳转到登录页。 是否有系统角色信息需要通过异步请求来获取。 需求分析&实现 对需求进行抽...
阅读 2260·2023-04-25 14:50
阅读 1232·2021-10-13 09:50
阅读 1866·2019-08-30 15:56
阅读 1838·2019-08-29 15:29
阅读 2886·2019-08-29 15:27
阅读 3547·2019-08-29 15:14
阅读 1192·2019-08-29 13:01
阅读 3298·2019-08-26 14:06