【前端】正则表达式验证密码

技术栈:
vue-cli + element ui

验证规则:

  • 至少有六个字符长
  • 包含以下四类字符中的三类字符:
    • 英文大写字母(A 到 Z)
    • 英文小写字母(a 到 z)
    • 10 个基本数字(0 到 9)
    • 非字母字符(例如 !、$、#、%)

代码:

function validatePass(rule, value, callback) {
  //是否包含数字
  var ptr_digit = /^.*[0-9]+.*$/;
  //是否包含小写字母
  var ptr_lowcase = /^.*[a-z]+.*$/;
  //是否包含大写字母
  var ptr_upcase = /^.*[A-Z]+.*$/;
  //是否包含特殊字符(非数字、字母的字符)
  var ptr_special = /((?=[\x21-\x7e]+)[^A-Za-z0-9])/;
  // var ptr_special = /^.*[~`!@#$%^&*()_+|<>,.?/:;'\\[\\]{}\"]+.*$/;

  if(value.length < 6) {
    callback(new Error('密码至少6位'));
  }
  else if((ptr_digit.test(value) && ptr_lowcase.test(value) && ptr_upcase.test(value) && ptr_special.test(value))
          || (!ptr_digit.test(value) && ptr_lowcase.test(value) && ptr_upcase.test(value) && ptr_special.test(value))
          || (ptr_digit.test(value) && !ptr_lowcase.test(value) && ptr_upcase.test(value) && ptr_special.test(value))
          || (ptr_digit.test(value) && ptr_lowcase.test(value) && !ptr_upcase.test(value) && ptr_special.test(value))
          || (ptr_digit.test(value) && ptr_lowcase.test(value) && ptr_upcase.test(value) && !ptr_special.test(value))){
    callback();
  }
  else {
    callback(new Error("至少包含大写字母、小写字母、数字、特殊字符中的三类字符"))
  }
}

你可能感兴趣的:(前端)