美文网首页
vue中关于密码复杂度的校验

vue中关于密码复杂度的校验

作者: 梦夜空中最亮的星 | 来源:发表于2017-12-06 10:21 被阅读0次

以下代码是根据自己的项目里面关于密码复杂度的一个校验,也比较符合目前比较主流的校验规则,并且进行了相应的优化;

import  passwordValid  from  formValidation;

passwordValidCheck(){

var userName = 'linxi_01' ;

var passWord= '123465798' ;

var flag=passwordValid(userName,passWord);

console.log(flag);

}

我们把passwordValid方法写在外部,可以在任何你想调用的组件里面引入即可,非常方便,具体校验看代码:

//  是否符合密码复杂度要求。

/* 密码要求有 数字、大写字母、小写字母 特殊字符 任选3种 的组合, 密码最小长度最少要求有8位,最大20位

* 新密码中不能够包含帐户。

* 密码中不能包含有连续四位及以上顺序(或逆序)数字(如:密码中不能包含1234或3210等)。

* 密码中不能包含有连续四位及以上顺序(或逆序)字母,字母不区分大小写(如:密码中不能包含abcd或ABCD或AbcD或DcbA等)。

* 密码中不能包含有连续四位及以上重复字符,字母不区分大小写(如:密码中不能包含8888、aaaa 或AAAA或BbbB或 $$$$等四位及以上的重复字符)。

* 禁忌词不区分大小写不能作为密码的一部分存在于密码中(如:admin, pass)。

*/

export function passwordValid(userName, pass) {

var passLower = pass.toLocaleLowerCase();

var flag = ' ' ;

if (pass == null || pass.length < 8 || pass.length > 20 || pass.length == '') {

//$.messager.alert("错误","密码位数不对,长度最少8位,最大20位。");

flag = '密码位数不对,长度最少8位,最大20位';

return flag;

}

// 判断是否默认密码

// if (isDefaultPass(userName, pass))

// {

// return "密码为默认密码或弱口令";

// }

// 是数字

var isDigit = /^.*[0-9]+.*/;

// isLowerCase 小写字母

var isLowerCase = /^.*[a-z]+.*/;

// isUpperCase 大写字母

var isUpperCase = /^.*[A-Z]+.*/;

// 特殊字符

var regEx = /^.*[^a-zA-Z0-9]+.*/;

// 记录匹配的次数

var num = 0;

if (isDigit.test(pass)) {

num = num + 1;

}

if (isLowerCase.test(pass)) {

num = num + 1;

}

if (isUpperCase.test(pass)) {

num = num + 1;

}

if (regEx.test(pass)) {

num = num + 1;

}

if (num <= 2) {

//$.messager.alert("错误","密码复杂度不足,\n(1)大写字母\n(2)小写字母\n(3)数字\n(4)特殊符号\n密码至少需包含上述情形中的三种.");

flag = '密码复杂度不足,\n(1)大写字母\n(2)小写字母\n(3)数字\n(4)特殊符号\n密码至少需包含上述情形中的三种';

return flag;

}

//新密码中不能够包含帐户。

if (pass.indexOf(userName) >= 0) {

//$.messager.alert("错误","新密码不能包含用户名.");

flag = '新密码不能包含用户名';

return flag;

}

//密码中不能包含有连续四位及以上顺序(或逆序)数字(如:密码中不能包含1234或3210等)。

var numberSequence = false;

for (var i = 0; i < pass.length - 3; i++) {

if (!isDigit.test(pass.substring(i, i + 1)) || !isDigit.test(pass.substring(i + 1, i + 2) + "") || !isDigit.test(pass.substring(i + 2, i + 3) + "") || !isDigit.test(pass.substring(i + 3, i + 4) + "")) {

continue;

}

var no1 = Number(pass.substring(i, i + 1));

var no2 = Number(pass.substring(i + 1, i + 2));

var no3 = Number(pass.substring(i + 2, i + 3));

var no4 = Number(pass.substring(i + 3, i + 4));

if (no1 + 1 == no2 && no2 + 1 == no3 && no3 + 1 == no4) {

numberSequence = true;

}

if (no2 + 1 == no1 && no3 + 1 == no2 && no4 + 1 == no3) {

numberSequence = true;

}

}

if (numberSequence) {

// $.messager.alert("错误","密码中不能包含有连续四位及以上顺序(或逆序)数字(如:密码中不能包含1234或3210等)。");

falg = '密码中不能包含有连续四位及以上顺序(或逆序)数字(如:密码中不能包含1234或3210等';

return flag;

}

//密码中不能包含有连续四位及以上顺序(或逆序)字母,字母不区分大小写(如:密码中不能包含abcd或ABCD或AbcD或DcbA等)。

var letterSequence = false;

for (var i = 0; i < passLower.length - 3; i++) {

if (!isLowerCase.test(passLower.substring(i, i + 1)) || !isLowerCase.test(passLower.substring(i + 1, i + 2) + "") || !isLowerCase.test(passLower.substring(i + 2, i + 3) + "") || !isLowerCase.test(passLower.substring(i + 3, i + 4) + "")) {

continue;

}

var no1 = passLower.charAt(i).charCodeAt() + 0;

var no2 = passLower.charAt(i + 1).charCodeAt() + 0;

var no3 = passLower.charAt(i + 2).charCodeAt() + 0;

var no4 = passLower.charAt(i + 3).charCodeAt() + 0;

if (no1 + 1 == no2 && no2 + 1 == no3 && no3 + 1 == no4) {

letterSequence = true;

}

if (no2 + 1 == no1 && no3 + 1 == no2 && no4 + 1 == no3) {

letterSequence = true;

}

}

if (letterSequence) {

//$.messager.alert("错误","密码中不能包含有连续四位及以上顺序(或逆序)字母,字母不区分大小写(如:密码中不能包含abcd或ABCD或AbcD或DcbA等)。");

flag = '密码中不能包含有连续四位及以上顺序(或逆序)字母,字母不区分大小写(如:密码中不能包含abcd或ABCD或AbcD或AbcD或DcbA等';

return flag;

}

//密码中不能包含有连续四位及以上重复字符,字母不区分大小写(如:密码中不能包含8888、aaaa 或AAAA或BbbB或 $$$$等四位及以上的重复字符)。

var fourOrMoreSame = false;

for (var i = 0; i < pass.length - 3; i++) {

if ((passLower.charAt(i)) == passLower.charAt(i + 1) &&

passLower.charAt(i + 1) == passLower.charAt(i + 2) &&

passLower.charAt(i + 2) == passLower.charAt(i + 3)) {

fourOrMoreSame = true;

}

}

if (fourOrMoreSame) {

//  $.messager.alert("错误","密码中不能包含有连续四位及以上重复字符,字母不区分大小写(如:密码中不能包含8888、aaaa 或AAAA或BbbB或 $$$$等四位及以上的重复字符)。");

flag = '密码中不能包含有连续四位及以上重复字符,字母不区分大小写(如:密码中不能包含8888、aaaa 或AAAA或BbbB或 $$$$等四位及以上的重复字符';

return flag;

}

var cont = /^.*admin.*$/;

var cont2 = /^.*pass.*$/;

//禁忌词不区分大小写不能作为密码的一部分存在于密码中(如:admin, pass)。

if (cont.test(passLower) || cont2.test(passLower)) {

//  $.messager.alert("错误","禁忌词不区分大小写不能作为密码的一部分存在于密码中(如:admin, pass)。");

flag = '禁忌词不区分大小写不能作为密码的一部分存在于密码中(如:admin, pass)';

return flag;

}

return 'correct';

}

相关文章

  • vue中关于密码复杂度的校验

    以下代码是根据自己的项目里面关于密码复杂度的一个校验,也比较符合目前比较主流的校验规则,并且进行了相应的优化; i...

  • 密码强度校验-前端js

    使用js对用户输入的密码进行强度校验 密码复杂度提示:当用户输入密码后,页面显示提示用户输入密码的复杂度(低、中、...

  • 前端数据处理--密码复杂度验证方法

    前端有时候需要对用户输入的密码进行校验处理,除可做加密处理外,有时应业务需求还要做密码复杂度的校验。(最好是...

  • 密码复杂度校验

    1、密码中必须包含大小字母、数字、特称字符,至少8个字符,最多30个字符。 2、密码中必须包含字母、数字、特称字符...

  • 登录密码校验的相对安全策略

    通信安全是现在APP安全的重中之重,所以参考他人总结了关于密码校验的策略通常有几种校验方式保证密码的安全 md5 ...

  • wrs-gesturelockview

    前言 手势密码控件,支持密码设置、密码修改、密码校验 功能 支持密码设置、密码修改、密码校验 密码设置或修改回调,...

  • JS实现校验密码强度

    /* *@description 校验密码强度的方法 *@param {String} val 待校验强度的密码 ...

  • 16 CentOS7登录安全修复——密码复杂度-登录限制-roo

    一、密码复杂度设置 CentOS密码复杂度配置通过/etc/pam.d/system-auth文件中的pam_cr...

  • 铁犀牛学习笔记(一)

    问题:Ironrhino用户登录中的密码校验流程、OAuth认证、token校验实现过程 用户登录认证过程总结: ...

  • 设计模式之责任链模式

    抽象处理者 校验的具体规则类 校验用户昵称 校验邮箱 校验状态 校验密码 校验规则客户端 输出结果

网友评论

      本文标题:vue中关于密码复杂度的校验

      本文链接:https://www.haomeiwen.com/subject/tylkixtx.html