• 常用正则整理


    1、手机号:^1[34578]d{9}$

    2、邮箱:^([A-Za-z0-9_-.])+@([A-Za-z0-9_-.])+.([A-Za-z]{2,4})$

    3、电话:^((d{3,4}-)|d{3.4}-)?d{7,8}$

     【"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX】

    4、英文字母开头,字母+数字+下滑线:^[a-zA-Z][a-zA-Z0-9_]*$

    5、正整数:^+?[1-9][0-9]*$

    6、网址:^((ht|f)tps?)://([w-]+(.[w-]+)*/)*[w-]+(.[w-]+)*/?(?([w-.,@?^=%&:/~+#]*)+)?

    7、正的,小数部分以5结尾的浮点数 或 正整数:^[1-9]d*.[5]$|0.[5]$|^[1-9]d*$

    8、身份证:

          const idcardReg = /^(^[1-9]d{7}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}$)|(^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])((d{4})|d{3}[Xx])$)$/;
          if (!idcardReg.test(this.idCardNo)) {
            this.srv['warn']('请填写正确的证件号码', 3500);
            return;
          } else {
            //如果通过该验证,说明身份证格式正确,但准确性还需计算
            if (this.idCardNo.length == 18) {
              var idCardWi = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); //将前17位加权因子保存在数组里
              var idCardY = new Array(1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2); //这是除以11后,可能产生的11位余数、验证码,也保存成数组
              var idCardWiSum = 0; //用来保存前17位各自乖以加权因子后的总和
              for (var i = 0; i < 17; i++) {
                idCardWiSum += this.idCardNo.substring(i, i + 1) * idCardWi[i];
              }
              var idCardMod = idCardWiSum % 11;//计算出校验码所在数组的位置
              var idCardLast = this.idCardNo.substring(17);//得到最后一位身份证号码
              //如果等于2,则说明校验码是10,身份证号码最后一位应该是X
              if (idCardMod == 2) {
                if (idCardLast == 'X' || idCardLast == 'x') {
                  //  console.log('恭喜通过验证啦!');
                } else {
                  this.srv['warn']('身份证号码错误!', 3500);
                  return;
                }
              } else {
                //用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
                if (idCardLast == idCardY[idCardMod]) {
                  //  console.log('恭喜通过验证啦!');
                } else {
                  this.srv['warn']('身份证号码错误!', 3500);
                  return;
                }
              }
            }
          }

    第二代身份证号码编排规则: https://jingyan.baidu.com/article/72ee561abd962fe16038df48.html

     

  • 相关阅读:
    BUPT复试专题—最小距离查询(2013)
    BUPT复试专题—中序遍历序列(2013)
    BUPT复试专题—统计节点个数(2013)
    BUPT复试专题—日期(2013)
    BUPT复试专题—内存分配(2014-2)
    BUPT复试专题—图像识别(2014-2)
    Catch That Cow(BFS)
    Pet(hdu 4707 BFS)
    Knight Moves(BFS,走’日‘字)
    Lost Cows(BIT poj2182)
  • 原文地址:https://www.cnblogs.com/boreguo/p/10999706.html
Copyright © 2020-2023  润新知