zoukankan      html  css  js  c++  java
  • 常用正则整理

    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

     

  • 相关阅读:
    Codeforces1101G (Zero XOR Subset)-less 【线性基】【贪心】
    Codeforces1101F Trucks and Cities 【滑动窗口】【区间DP】
    HDU4651 Partition 【多项式求逆】
    BZOJ2554 color 【概率DP】【期望DP】
    codeforces1101D GCD Counting 【树形DP】
    codechef EBAIT Election Bait【欧几里得算法】
    BZOJ2434 [NOI2011] 阿狸的打字机 【树链剖分】【线段树】【fail树】【AC自动机】
    codeforces1093G Multidimensional Queries 【线段树】
    BZOJ3277 串 【后缀数组】【二分答案】【主席树】
    AHOI2013 差异 【后缀数组】
  • 原文地址:https://www.cnblogs.com/boreguo/p/10999706.html
Copyright © 2011-2022 走看看