java密码强度_java实现的密码强度检测功能完整示例

本文介绍了使用Java编写的密码强度检测功能,包括检查密码的字符类型、长度、包含的字符组合,以及防止常见字典攻击。通过CheckStrength类进行强度评估,返回密码强度等级。
摘要由CSDN通过智能技术生成

本文实例讲述了java实现的密码强度检测功能。分享给大家供大家参考,具体如下:

CheckStrength.java文件:

package com.wx.pwd;

/**

* 检测密码强度

*

* @author venshine

*/

public class CheckStrength {

public enum LEVEL {

EASY, MIDIUM, STRONG, VERY_STRONG, EXTREMELY_STRONG

}

/**

* NUM 数字

* SMALL_LETTER 小写字母

* CAPITAL_LETTER 大写字母

* OTHER_CHAR 特殊字符

*/

private static final int NUM = 1;

private static final int SMALL_LETTER = 2;

private static final int CAPITAL_LETTER = 3;

private static final int OTHER_CHAR = 4;

/**

* 简单的密码字典

*/

private final static String[] DICTIONARY = {"password", "abc123", "iloveyou", "adobe123", "123123", "sunshine",

"1314520", "a1b2c3", "123qwe", "aaa111", "qweasd", "admin", "passwd"};

/**

*检查字符类型,包括num、大写字母、小写字母和其他字符。

*

* @param c

* @return

*/

private static int checkCharacterType(char c) {

if (c >= 48 && c <= 57) {

return NUM;

}

if (c >= 65 && c <= 90) {

return CAPITAL_LETTER;

}

if (c >= 97 && c <= 122) {

return SMALL_LETTER;

}

return OTHER_CHAR;

}

/**

* 按不同类型计算密码的数量

*

* @param passwd

* @param type

* @return

*/

private static int countLetter(String passwd, int type) {

int count = 0;

if (null != passwd && passwd.length() > 0) {

for (char c : passwd.toCharArray()) {

if (checkCharacterType(c) == type) {

count++;

}

}

}

return count;

}

/**

* 检查密码的强度

*

* @param passwd

* @return strength level

*/

public static int checkPasswordStrength(String passwd) {

if (StringUtils.equalsNull(passwd)) {

throw new IllegalArgumentException("password is empty");

}

int len = passwd.length();

int level = 0;

// 增加点

//判断密码是否含有数字有level++

if (countLetter(passwd, NUM) > 0) {

level++;

}

//判断密码是否含有小写字母有level++

if (countLetter(passwd, SMALL_LETTER) > 0) {

level++;

}

//判断密码是否还有大写字母有level++

if (len > 4 && countLetter(passwd, CAPITAL_LETTER) > 0) {

level++;

}

//判断密码是否还有特殊字符有level++

if (len > 6 && countLetter(passwd, OTHER_CHAR) > 0) {

level++;

}

//密码长度大于4并且2种类型组合......(不一一概述)

if (len > 4 && countLetter(passwd, NUM) > 0 && countLetter(passwd, SMALL_LETTER) > 0

|| countLetter(passwd, NUM) > 0 && countLetter(passwd, CAPITAL_LETTER) > 0

|| countLetter(passwd, NUM) > 0 && countLetter(passwd, OTHER_CHAR) > 0

|| countLetter(passwd, SMALL_LETTER) > 0 && countLetter(passwd, CAPITAL_LETTER) > 0

|| countLetter(passwd, SMALL_LETTER) > 0 && countLetter(passwd, OTHER_CHAR) > 0

|| countLetter(passwd, CAPITAL_LETTER) > 0 && countLetter(passwd, OTHER_CHAR) > 0) {

level++;

}

//密码长度大于6并且3中类型组合......(不一一概述)

if (len > 6 && countLetter(passwd, NUM) > 0 && countLetter(passwd, SMALL_LETTER) > 0

&& countLetter(passwd, CAPITAL_LETTER) > 0 || countLetter(passwd, NUM) > 0

&& countLetter(passwd, SMALL_LETTER) > 0 && countLetter(passwd, OTHER_CHAR) > 0

|| countLetter(passwd, NUM) > 0 && countLetter(passwd, CAPITAL_LETTER) > 0

&& countLetter(passwd, OTHER_CHAR) > 0 || countLetter(passwd, SMALL_LETTER) > 0

&& countLetter(passwd, CAPITAL_LETTER) > 0 && countLetter(passwd, OTHER_CHAR) > 0) {

level++;

}

//密码长度大于8并且4种类型组合......(不一一概述)

if (len > 8 && countLetter(passwd, NUM) > 0 && countLetter(passwd, SMALL_LETTER) > 0

&& countLetter(passwd, CAPITAL_LETTER) > 0 && countLetter(passwd, OTHER_CHAR) > 0) {

level++;

}

//密码长度大于6并且2种类型组合每种类型长度大于等于3或者2......(不一一概述)

if (len > 6 && countLetter(passwd, NUM) >= 3 && countLetter(passwd, SMALL_LETTER) >= 3

|| countLetter(passwd, NUM) >= 3 && countLetter(passwd, CAPITAL_LETTER) >= 3

|| countLetter(passwd, NUM) >= 3 && countLetter(passwd, OTHER_CHAR) >= 2

|| countLetter(passwd, SMALL_LETTER) >= 3 && countLetter(passwd, CAPITAL_LETTER) >= 3

|| countLetter(passwd, SMALL_LETTER) >= 3 && countLetter(passwd, OTHER_CHAR) >= 2

|| countLetter(passwd, CAPITAL_LETTER) >= 3 && countLetter(passwd, OTHER_CHAR) >= 2) {

level++;

}

//密码长度大于8并且3种类型组合每种类型长度大于等于3或者2......(不一一概述)

if (len > 8 && countLetter(passwd, NUM) >= 2 && countLetter(passwd, SMALL_LETTER) >= 2

&& countLetter(passwd, CAPITAL_LETTER) >= 2 || countLetter(passwd, NUM) >= 2

&& countLetter(passwd, SMALL_LETTER) >= 2 && countLetter(passwd, OTHER_CHAR) >= 2

|| countLetter(passwd, NUM) >= 2 && countLetter(passwd, CAPITAL_LETTER) >= 2

&& countLetter(passwd, OTHER_CHAR) >= 2 || countLetter(passwd, SMALL_LETTER) >= 2

&& countLetter(passwd, CAPITAL_LETTER) >= 2 && countLetter(passwd, OTHER_CHAR) >= 2) {

level++;

}

//密码长度大于10并且4种类型组合每种类型长度大于等于2......(不一一概述)

if (len > 10 && countLetter(passwd, NUM) >= 2 && countLetter(passwd, SMALL_LETTER) >= 2

&& countLetter(passwd, CAPITAL_LETTER) >= 2 && countLetter(passwd, OTHER_CHAR) >= 2) {

level++;

}

//特殊字符>=3 level++;

if (countLetter(passwd, OTHER_CHAR) >= 3) {

level++;

}

//特殊字符>=6 level++;

if (countLetter(passwd, OTHER_CHAR) >= 6) {

level++;

}

//长度>12 >16 level++

if (len > 12) {

level++;

if (len >= 16) {

level++;

}

}

// 减少点

if ("abcdefghijklmnopqrstuvwxyz".indexOf(passwd) > 0 || "ABCDEFGHIJKLMNOPQRSTUVWXYZ".indexOf(passwd) > 0) {

level--;

}

if ("qwertyuiop".indexOf(passwd) > 0 || "asdfghjkl".indexOf(passwd) > 0 || "zxcvbnm".indexOf(passwd) > 0) {

level--;

}

if (StringUtils.isNumeric(passwd) && ("01234567890".indexOf(passwd) > 0 || "09876543210".indexOf(passwd) > 0)) {

level--;

}

if (countLetter(passwd, NUM) == len || countLetter(passwd, SMALL_LETTER) == len

|| countLetter(passwd, CAPITAL_LETTER) == len) {

level--;

}

if (len % 2 == 0) { // aaabbb

String part1 = passwd.substring(0, len / 2);

String part2 = passwd.substring(len / 2);

if (part1.equals(part2)) {

level--;

}

if (StringUtils.isCharEqual(part1) && StringUtils.isCharEqual(part2)) {

level--;

}

}

if (len % 3 == 0) { // ababab

String part1 = passwd.substring(0, len / 3);

String part2 = passwd.substring(len / 3, len / 3 * 2);

String part3 = passwd.substring(len / 3 * 2);

if (part1.equals(part2) && part2.equals(part3)) {

level--;

}

}

if (StringUtils.isNumeric(passwd) && len >= 6) { // 19881010 or 881010

int year = 0;

if (len == 8 || len == 6) {

year = Integer.parseInt(passwd.substring(0, len - 4));

}

int size = StringUtils.sizeOfInt(year);

int month = Integer.parseInt(passwd.substring(size, size + 2));

int day = Integer.parseInt(passwd.substring(size + 2, len));

if (year >= 1950 && year < 2050 && month >= 1 && month <= 12 && day >= 1 && day <= 31) {

level--;

}

}

if (null != DICTIONARY && DICTIONARY.length > 0) {// dictionary

for (int i = 0; i < DICTIONARY.length; i++) {

if (passwd.equals(DICTIONARY[i]) || DICTIONARY[i].indexOf(passwd) >= 0) {

level--;

break;

}

}

}

if (len <= 6) {

level--;

if (len <= 4) {

level--;

if (len <= 3) {

level = 0;

}

}

}

if (StringUtils.isCharEqual(passwd)) {

level = 0;

}

if (level < 0) {

level = 0;

}

return level;

}

/**

*获得密码强度等级,包括简单、复杂、强、强、强

*

* @param passwd

* @return

*/

public static LEVEL getPasswordLevel(String passwd) {

int level = checkPasswordStrength(passwd);

switch (level) {

case 0:

case 1:

case 2:

case 3:

return LEVEL.EASY;

case 4:

case 5:

case 6:

return LEVEL.MIDIUM;

case 7:

case 8:

case 9:

return LEVEL.STRONG;

case 10:

case 11:

case 12:

return LEVEL.VERY_STRONG;

default:

return LEVEL.EXTREMELY_STRONG;

}

}

}

StringUtils.java文件:

package com.wx.pwd;

/**

* 字符串工具类

*

* @author venshine

*/

public class StringUtils {

private final static int[] SIZE_TABLE = {9, 99, 999, 9999, 99999, 999999, 9999999, 99999999, 999999999,

Integer.MAX_VALUE};

/**

* 计算一个整数的大小

*

* @param x

* @return

*/

public static int sizeOfInt(int x) {

for (int i = 0; ; i++)

if (x <= SIZE_TABLE[i]) {

return i + 1;

}

}

/**

* 判断字符串的每个字符是否相等

*

* @param str

* @return

*/

public static boolean isCharEqual(String str) {

return str.replace(str.charAt(0), ' ').trim().length() == 0;

}

/**

* 确定字符串是否为数字

*

* @param str

* @return

*/

public static boolean isNumeric(String str) {

for (int i = str.length(); --i >= 0; ) {

if (!Character.isDigit(str.charAt(i))) {

return false;

}

}

return true;

}

/**

* 判断字符串是否为空格、空(“)”或null。

*

* @param str

* @return

*/

public static boolean equalsNull(String str) {

int strLen;

if (str == null || (strLen = str.length()) == 0 || str.equalsIgnoreCase("null")) {

return true;

}

for (int i = 0; i < strLen; i++) {

if ((Character.isWhitespace(str.charAt(i)) == false)) {

return false;

}

}

return true;

}

}

CheckPWD.java文件:

package com.wx.pwd;

public class CheckPWD {

public static void main(String[] args) {

String passwd = "myNameJOB123_-+=";

System.out.println(CheckStrength.checkPasswordStrength(passwd));

System.out.println(CheckStrength.getPasswordLevel(passwd));

}

}

运行结果:

13

EXTREMELY_STRONG

PS:这里再为大家提供两款功能类似的在线工具供大家参考:

希望本文所述对大家java程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值