国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 課堂 > 小程序 > 正文

微信小程序身份證驗證方法實現詳解

2020-03-21 15:53:08
字體:
來源:轉載
供稿:網友

身份證驗證在很多小程序中已經成為必不可少的一部分,它能有效的判斷出身份證是否存在,是否輸入錯誤,以防不良人士惡意攻擊。

判斷一個身份證是否合法的身份證號碼有以下幾個步驟需要驗證

①:身份證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)?/d{2}(0[1-9]|1[012])(0[1-9]|[12]/d|3[01])/d{3}(/d|X)$/; if(!code || !code.match(reg)) { tip = "身份證號格式錯誤"; 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。如果是錯誤的身份證號碼,會提示那里錯誤。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 上杭县| 和田县| 陆河县| 孟州市| 宜宾市| 霍山县| 孙吴县| 阿尔山市| 手机| 平邑县| 宜宾县| 泽普县| 苗栗县| 鸡西市| 鹤壁市| 寿光市| 大名县| 密云县| 青铜峡市| 碌曲县| 佛山市| 沭阳县| 沙田区| 大关县| 通化县| 平江县| 彰武县| 郸城县| 池州市| 乌海市| 新巴尔虎左旗| 松溪县| 阳新县| 论坛| 隆子县| 绥阳县| 阿鲁科尔沁旗| 海安县| 长寿区| 康保县| 若羌县|