微信小程序身份證驗(yàn)證方法實(shí)現(xiàn)詳解
身份證驗(yàn)證在很多小程序中已經(jīng)成為必不可少的一部分,它能有效的判斷出身份證是否存在,是否輸入錯(cuò)誤,以防不良人士惡意攻擊。
判斷一個(gè)身份證是否合法的身份證號(hào)碼有以下幾個(gè)步驟需要驗(yàn)證
①:身份證18位數(shù)
②:前17位全是數(shù)字
③:驗(yàn)證最后一位
1.前面的身份證號(hào)碼17位數(shù)分別乘以不同的系數(shù) 從第一位到第十七位的系數(shù)分別為:7-9-10-5-8-4-2-1-6-3-7-9-10-5-8-4-2。
2.將這17位數(shù)字和系數(shù)相乘的結(jié)果相加。
3.用加出來和模以11,看余數(shù)是多少?
4.余數(shù)只可能有0-1-2-3-4-5-6-7-8-9-10這11個(gè)數(shù)字。其分別對應(yīng)的最后一位身份證的號(hào)碼為1-0-X-9-8-7-6-5-4-3-2。
5.通過上面得知如果余數(shù)是3,就會(huì)在身份證的第18位數(shù)字上出現(xiàn)的是9。
6. 如果對應(yīng)的數(shù)字是10,身份證的最后一位號(hào)碼就是羅馬數(shù)字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>手機(jī)號(hào):</text> </view> <view class='box-shang_right'> <input placeholder='請輸入手機(jī)號(hào)' id='mobile' bindinput='bininput_mobile' auto-focus></input> </view> </view> <view> <text class='text2'>和你的關(guān)系</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身份證驗(yàn)證方法
/*身份證驗(yàn)證輸入是否正確 *身份證號(hào)合法性驗(yàn)證 *支持15位和18位身份證號(hào) *支持地址編碼、出生日期、校驗(yàn)位驗(yàn)證*/ getBirthAndSex: function (e) { var ts = this; var code = this.data.identity //identity 為你輸入的身份證 console.log(code) var city = { 11: "北京", 12: "天津", 13: "河北", 14: "山西", 15: "內(nèi)蒙古", 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: "臺(tái)灣", 81: "香港", 82: "澳門", 91: "國外 " }; var tip = ""; var pass = true; var reg = /^\d{6}(18|19|20)?\d{2}(0[1-9]|1[012])(0[1-9]|[12]\d|3[01])\d{3}(\d|X)$/; if(!code || !code.match(reg)) { tip = "身份證號(hào)格式錯(cuò)誤"; pass = false; } else if (!city[code.substr(0, 2)]) { tip = "地址編碼錯(cuò)誤"; pass = false; } else { //18位身份證需要驗(yàn)證最后一位校驗(yàn)位 if (code.length == 18) { code = code.split(''); //∑(ai×Wi)(mod 11) //加權(quán)因子 var factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]; //校驗(yàn)位 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 = "校驗(yàn)位錯(cuò)誤"; 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; }, ···
如果身份證輸入正確,控制臺(tái)輸出的是ture,反之false。如果是錯(cuò)誤的身份證號(hào)碼,會(huì)提示那里錯(cuò)誤。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Javascript中prototype屬性實(shí)現(xiàn)給內(nèi)置對象添加新的方法
這篇文章主要介紹了Javascript中prototype屬性實(shí)現(xiàn)給內(nèi)置對象添加新的方法,涉及javascript中prototype屬性的使用技巧,需要的朋友可以參考下2015-05-05JavaScript 井字棋人工智能實(shí)現(xiàn)代碼
JavaScript fights back in this artificial Tic Tac Toe game. Great script to have to entertain yourself and your visitors.2009-12-12Javascript實(shí)現(xiàn)商品秒殺倒計(jì)時(shí)(時(shí)間與服務(wù)器時(shí)間同步)
在一些購物商城經(jīng)??吹接泻芏嗌唐纷雒霘⒒顒?dòng),也就是倒計(jì)時(shí),本篇文章給大家介紹Javascript實(shí)現(xiàn)商品秒殺倒計(jì)時(shí)(時(shí)間與服務(wù)器時(shí)間同步),需要的朋友可以了解下2015-09-09微信小程序?qū)W習(xí)之?dāng)?shù)據(jù)處理詳解
這篇文章主要給大家介紹了關(guān)于微信小程序中數(shù)據(jù)處理的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考借鑒,下面來一起看看吧。2017-07-07VsCode插件自動(dòng)生成注釋插件koroFileHeader使用教程
這篇文章主要介紹了VsCode插件自動(dòng)生成注釋插件koroFileHeader使用教程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01基于JavaScript實(shí)現(xiàn)網(wǎng)頁倒計(jì)時(shí)自動(dòng)跳轉(zhuǎn)代碼
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)網(wǎng)頁倒計(jì)時(shí)自動(dòng)跳轉(zhuǎn)代碼 的相關(guān)資料,需要的朋友可以參考下2015-12-12