zoukankan      html  css  js  c++  java
  • 小程序正则校验身份证号

    前段时间在开发过程中涉及到用户身份证号校验,在此记录下:

      说明:我是将公共方法封装在一个js中,然后再需要使用的地方调用的。

     1 // util.js页面,封装的公共方法
     2 
     3 /**
     4  * 去掉字符串头尾空格
     5  */
     6 function trim(str) {
     7   return str.replace(/(^s*)|(s*$)/g, "");
     8 }
     9 
    10 /**
    11  * 身份证号验证
    12  */
    13 function checkIdCard(idCard) {
    14   idCard = trim(idCard.replace(/ /g, "")); //去掉字符串头尾空格                                          
    15   if (idCard.length == 15) {
    16     return isValidityBrithBy15IdCard(idCard); //进行15位身份证的验证    
    17   } else if (idCard.length == 18) {
    18     var a_idCard = idCard.split(""); // 得到身份证数组   
    19     if (isValidityBrithBy18IdCard(idCard) && isTrueValidateCodeBy18IdCard(a_idCard)) { //进行18位身份证的基本验证和第18位的验证
    20       return true;
    21     } else {
    22       return false;
    23     }
    24   } else {
    25     return false;
    26   }
    27 }
    28 
    29 /**  
    30  * 判断身份证号码为18位时最后的验证位是否正确  
    31  * @param a_idCard 身份证号码数组  
    32  * @return  
    33  */
    34 function isTrueValidateCodeBy18IdCard(a_idCard) {
    35   var Wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1]; // 加权因子
    36   var ValideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2];
    37   var sum = 0; // 声明加权求和变量   
    38   if (a_idCard[17].toLowerCase() == 'x') {
    39     a_idCard[17] = 10; // 将最后位为x的验证码替换为10方便后续操作   
    40   }
    41   for (var i = 0; i < 17; i++) {
    42     sum += Wi[i] * a_idCard[i]; // 加权求和   
    43   }
    44   var valCodePosition = sum % 11; // 得到验证码所位置   
    45   if (a_idCard[17] == ValideCode[valCodePosition]) {
    46     return true;
    47   } else {
    48     return false;
    49   }
    50 }
    51 
    52 /**  
    53  * 验证18位数身份证号码中的生日是否是有效生日  
    54  * @param idCard 18位书身份证字符串  
    55  * @return  
    56  */
    57 function isValidityBrithBy18IdCard(idCard18) {
    58   var year = idCard18.substring(6, 10);
    59   var month = idCard18.substring(10, 12);
    60   var day = idCard18.substring(12, 14);
    61   var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
    62   // 这里用getFullYear()获取年份,避免千年虫问题   
    63   if (temp_date.getFullYear() != parseFloat(year) ||
    64     temp_date.getMonth() != parseFloat(month) - 1 ||
    65     temp_date.getDate() != parseFloat(day)) {
    66     return false;
    67   } else {
    68     return true;
    69   }
    70 }
    71 
    72 /**  
    73  * 验证15位数身份证号码中的生日是否是有效生日  
    74  * @param idCard15 15位书身份证字符串  
    75  * @return  
    76  */
    77 function isValidityBrithBy15IdCard(idCard15) {
    78   var year = idCard15.substring(6, 8);
    79   var month = idCard15.substring(8, 10);
    80   var day = idCard15.substring(10, 12);
    81   var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
    82   // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法   
    83   if (temp_date.getYear() != parseFloat(year) ||
    84     temp_date.getMonth() != parseFloat(month) - 1 ||
    85     temp_date.getDate() != parseFloat(day)) {
    86     return false;
    87   } else {
    88     return true;
    89   }
    90 }
    91 
    92 // 这个属性是将方法名暴露出来,否则需要引用的页面取不到
    93 module.exports = {
    94   checkIdCard,
    95 }
    // pages/test/test.js
    const util = require('../../utils/util.js'); //路径根据自己的文件目录来
    
    Page({
    
      /**
       * 页面的初始数据
       */
      data: {
        value: '', //输入的是身份证号
      },
     
      /**
       * 获取输入的是身份证号
       */
    onChange(e) {
    this.setData({ value: e.detail.value }) }, /** * 保存 */ save() {if (!util.checkIdCard(this.data.value)) { wx.showToast({ title: '请输入正确的身份证号', icon: 'none' }) } else { wx.showToast({ title: '通过了', }) } }, })
  • 相关阅读:
    “花田喜事” 婚庆网站策划
    discuz 模块模板标签说明 DIY模块模板语法详解
    discuz x2.5 广告位开发学习(第二步:制作)
    DiscuzX2.5完整目录结构【模板目录template】
    Webservice 安全性访问
    X2.5 怎么关闭个人空间
    心中有佛,看人即佛;心中有屎,看人即屎
    discuz x2.5 广告位开发学习(第一步:摸索)
    UVA 128 Software CRC
    UVA 10791 Minimum Sum LCM
  • 原文地址:https://www.cnblogs.com/rzsyztd/p/12206433.html
Copyright © 2011-2022 走看看