身份证验证在很多小程序中已经成为必不可少的一部分,它能有效的判断出身份证是否存在,是否输入错误,以防不良人士恶意攻击。
判断一个身份证是否合法的身份证号码有以下几个步骤需要验证
①:身份证18位数
②:前17位全是数字
③:验证最后一位
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.通过上面得知如果余数是3,就会在身份证的第18位数字上出现的是9。
6. 如果对应的数字是10,身份证的最后一位号码就是罗马数字x。
wxml
<view class='box'> <view class='box-shang'> <view class='box-shang_left'> <text class='text1'>姓名:</text> </view> <view class='box-shang_right'> <input placeholder='请输入姓名' id='name' bindinput='bininput_name' auto-focus></input> </view> </view> <view class='box-shang'> <view class='box-shang_left'> <text>身份证:</text> </view> <view class='box-shang_right'> <input placeholder='请输入身份证' id='identity' bindinput='bininput_identity' auto-focus></input> </view> </view> <view class='box-shang'> <view class='box-shang_left'> <text>手机号:</text> </view> <view class='box-shang_right'> <input placeholder='请输入手机号' id='mobile' bindinput='bininput_mobile' auto-focus></input> </view> </view> <view> <text class='text2'>和你的关系</text> </view> </view>
js
//绑定输入的姓名 bininput_name: function (e) { this.setData({ name: e.detail.value }) }, //绑定输入的身份证 bininput_identity: function (e) { this.setData({ identity: e.detail.value }) }, //绑定输入的电话 bininput_mobile: function (e) { this.setData({ mobile: e.detail.value }) },
js身份证验证方法
/*身份证验证输入是否正确 *身份证号合法性验证 *支持15位和18位身份证号 *支持地址编码、出生日期、校验位验证*/ getBirthAndSex: function (e) { var ts = this; var code = this.data.identity //identity 为你输入的身份证 console.log(code) var city = { 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 tip = ""; var pass = true; var reg = /^\d{6}(18|19|20)"身份证号格式错误"; pass = false; } else if (!city[code.substr(0, 2)]) { tip = "地址编码错误"; pass = false; } else { //18位身份证需要验证最后一位校验位 if (code.length == 18) { code = code.split(''); //∑(ai×Wi)(mod 11) //加权因子 var factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]; //校验位 var parity = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2]; var sum = 0; var ai = 0; var wi = 0; for (var i = 0; i < 17; i++) { ai = code[i]; wi = factor[i]; sum += ai * wi; } var last = parity[sum % 11]; if (parity[sum % 11] != code[17]) { tip = "校验位错误"; pass = false; } } } console.log("pass==="+pass) if (pass) { ts.setData({ allow_id: true }); wx.setStorageSync("idcard", code) } if (!pass) console.log("tip" + tip); return pass; }, ···
如果身份证输入正确,控制台输出的是ture,反之false。如果是错误的身份证号码,会提示那里错误。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月26日
2024年11月26日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]