各类证件类型的格式校验

1、身份证校验

function isCardID(sId) {
  var that = this;
  var aCity = {
    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 iSum = 0;
  var info = "";
  if (!/^\d{17}(\d|x)$/i.test(sId)) {
    alert('您输入的身份证长度或格式错误');
    return false;
  }
  sId = sId.replace(/x$/i, "a");
  if (aCity[parseInt(sId.substr(0, 2))] == null) {
    alert('您的身份证地区非法');
    return false;
  }
  var sBirthday = sId.substr(6, 4) + "-" + Number(sId.substr(10, 2)) + "-" + Number(sId.substr(12, 2));
  var d = new Date(sBirthday.replace(/-/g, "/"));
  if (sBirthday != (d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d.getDate())) {
    alert('身份证上的出生日期非法');
    return false;
  }
  for (var i = 17; i >= 0; i--) {
    iSum += (Math.pow(2, i) % 11) * parseInt(sId.charAt(17 - i), 11);
  }
  if (iSum % 11 != 1) {
    alert('您输入的身份证号非法');
    return false;
  }
  return true;
}
2、统一写到一起,有需要的正则表达式直接去代码里粘

去掉字符串中的空格

function Trim(str,is_global)
{
    var result;
    result = str.replace(/(^\s+)|(\s+$)/g,"");
    if(is_global.toLowerCase()=="g")
    {
        result = result.replace(/\s/g,"");
    }
    return result;
}
获取长度

function GetLength (str) {
    return str.replace(/[\u0391-\uFFE5]/g,"aa").length;
}
统一的验证方法

function validCredNum (type,credNum){
    var validFlag = true;
    if (typeof credNum == "undefined" || credNum == null || credNum == "" || credNum == "-1") {
        validFlag = false;
    }else{
        if ("1" == type) {//身份证
            validFlag = isCardID(credNum);
        } else if ("3" == type){               //护照号
            GetLength(Trim(credNum,'g'))<3 ? validFlag = false : validFlag = true;
        }else if ("4" == type) {            //台湾居民来往大陆通行证(台胞证)、或港澳居民往来内地通行证(回乡证)
            GetLength(Trim(credNum,'g'))<8 ? validFlag = false : validFlag = true;
            // validFlag = (/^[a-zA-Z\d]{6,10}$/).test(credNum);
        }else if ("5" == type) {            //军官证/警官证
            GetLength(Trim(credNum,'g'))<10 || GetLength(Trim(credNum,'g'))>18? validFlag = false : validFlag = true;
            // validFlag = (/^[a-zA-Z\d]{6,10}$/).test(credNum);
        }else if ("6" == type) {            //异常身份证
            GetLength(Trim(credNum,'g'))!=18? validFlag = false : validFlag = true;
            // validFlag = (/^[a-zA-Z\d]{6,10}$/).test(credNum);
        } else if ("mobile" == type){//手机
            if(credNum.length == 10 && credNum.indexOf('09') == 0||credNum.length == 11 && credNum.indexOf('1') == 0){
                validFlag = true;
            }else{
                validFlag = false;
            }
            // validFlag = (/^[\+86|86]?1[3|4|5|7|8]\d{9}$/.test(credNum));
        } else if ("name" == type){//姓名
            let credName = Trim(credNum,'g');
            GetLength(credName)<3||(/\d+/g).test(credName)||(/[#&]/).test(credName)?validFlag = false:validFlag = true;
            // validFlag = (/^[\u4e00-\u9fa5a-zA-Z]{2,20}$/).test(credNum);
        } else if ("email" == type){//邮箱
            validFlag = (/^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/.test(credNum));
        } else if ("postCode" == type){//邮政编码
            validFlag = (/^[0-9]{6}$/).test(credNum);
        } else if ("passWord" == type){ //密码验证 6-20位,字母、数字、符号的组合
            validFlag = (/^[\w.]{6,20}$/).test(credNum)
        } else if ('number' == type){     //验证是否为全数字
            validFlag = (/^(\d|[1-9]\d+)(\.\d+)?$/).test(credNum)
        } else if('symbol' == type){
            validFlag = (/[\u4E00-\u9FA5]/g).test(Trim(credNum,'g'))              //详细地址
        }else if('protection' == type){
            validFlag = (/^[a-zA-Z0-9]{3,21}$/||/^(P\d{7})|(G\d{8})$/).test(credNum)     //护照
        }else if('officers' == type){
            validFlag = (/^[a-zA-Z0-9]{7,21}$/).test(credNum)     //军官证
        }else if('book' == type){
            validFlag = ( /^[a-zA-Z0-9]{3,21}$/).test(credNum)     //  户口本
        }else if('bankCard' == type){
            validFlag = ( /^(\d{16}|\d{19})$/).test(credNum)     //  银行卡
        }else if('telephone' == type){
            if(credNum.indexOf('400') == 0 ||credNum.indexOf('800') == 0){
                if(credNum.length !=10){
                    validFlag = false
                }
            }else {
                validFlag = (/^0\d{2,3}-?\d{7,8}$/).test(credNum)
            }
        }
    }
    return validFlag;
};

今天遇到了一个手机号的校验,11位数字,第二位是3,4,5,7,8,最后8位不能是8位连续相同数字

补充一个这个正则表达式:

/^1[3,4,5,7,8]\d(?!(\d)\1{7})\d{8}$/





### Kubernetes 证书配置生产环境使用指南 在 Kubernetes 中,证书用于保障集群内部通信的安全性和身份验证。以下是关于如何在生产环境中正确配置和管理 Kubernetes 证书的详细说明。 #### 一、创建并导入现有证书 当需要使用现有的 TLS 证书来配置 HTTPS 服务时,可以通过 `kubectl` 命令将其作为 Secret 对象存储到指定命名空间中。具体操作如下: ```bash kubectl create secret tls example-secret \ --key cert/xxx.key \ --cert cert/xxx.pem \ -n NAMESPACE ``` 上述命令会将 `.pem` 和 `.key` 文件打包成名为 `example-secret` 的 Secret,并绑定至目标命名空间[^1]。 #### 二、更新 Kubernetes 集群中的证书 如果未启用自动更新机制,则需手动完成证书刷新工作。对于 Master 节点上的核心组件(如 etcd、API Server 等),可遵循以下流程实现单次或周期性的证书替换: 1. **准备新证书**:重新签发适用于各个子系统的公私钥对; 2. **分发密钥材料**:将生成的新文件同步部署到对应节点路径下; 3. **重启关联进程**:依次停止再启动涉及的服务实例以加载最新凭据数据[^2]; 值得注意的是,在此过程中务必小心处理好时间窗口安排以免影响线上业务运行状态。 #### 三、Master 组件所需各类证书概述 整个 K8S 架构依赖多种类型的 X.509 数字凭证支持其正常运转功能模块间相互认证需求。主要包括但不限于以下几个方面: - Etcd 数据库访问控制; - Apiserver 客户端请求授权校验 ; - Front Proxy 反向代理链路加密保护等等... 这些都要求各自独立的一套完整的 CA根证+子级签署实体组合形式存在以便于灵活调整权限范围同时保持高度安全性标准[^3]. #### 四、其他注意事项 除了以上提到的内容之外还有几个要点值得特别关注: - 所有资源定义文档里的字段名均采用`.`号连接表达层级关系方便解析定位特定属性值位置. - 如果希望定制化容器初始化行为则可以在 pod 描述里添加 command 参数覆盖原始镜像设定好的默认入口逻辑. 通过合理规划实施上述措施能够有效提升实际应用场景下的稳定性表现水平同时也降低了潜在风险发生的可能性. ```yaml apiVersion: v1 kind: Pod metadata: name: my-pod spec: containers: - name: main-container image: busybox command: ["sh", "-c", "echo Hello && sleep 3600"] ``` 上面展示了一个简单的例子演示怎样设置自定义启动指令给定名称为my-pod的对象体内包含唯一的一个container单元它将以busybox为基础映射执行一段打印消息接着长时间挂起等待终止信号到来为止[^5]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值