Java自定义强密码校验

11 篇文章 0 订阅

常用密码校验正则:

	// 必填数字、大小写字母,且至少8位
	String regex = "^(?=.*\\d)(?=.*[a-z])(?=.*[A-Z])[a-zA-Z0-9]{8,}$";
	// 必填数字、字母、特殊字符,且以字母开头,至少8位以上
	String strongRegex = "^(?![0-9]+$)(?![^0-9]+$)(?![a-zA-Z]+$)(?![^a-zA-Z]+$)(?![a-zA-Z0-9]+$)[a-zA-Z0-9\\S]{8,}$";

但是这种正则通常不能满足我们的需要。

现在的需求是:密码必须由数字大写字母小写字母特殊字符这四种,任意3种及以上排列组合,且至少8位。

自定义强密码校验的实现:

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.util.ArrayList;
import java.util.List;

/**
 * @author zy
 * @date 2021/12/7 16:11
 */
public class CheckPasswordUtils {

    /**
     * 密码强度检查。数字、小写字母、大写字母、特殊字符 4种任意满足3种及以上即可校验成功
     */
    public static boolean check(String password){
        // 空对象、空字符串、长度小于8 -> 验证不通过
        if (Utils.isNullOrEmpty(password)) return false;
        if (password.length() < 8) return false;
        StringCounter counter = new StringCounter().initInstance(password);
        int kinds = counter.getKinds();
        // 四种字符,任意3种即可
        return kinds > 2;
    }

    /**
     * main函数测试
     */
    public static void main(String[] args) {
        List<String> passwordList = new ArrayList<>();
        passwordList.add(null); // 验证空对象
        passwordList.add(""); // 验证空字符串
        passwordList.add("123456"); // 验证密码长度
        passwordList.add("lps123456"); // 验证种类
        passwordList.add("Lps123456"); // 验证正常密码
        passwordList.add("Lps*20210831*"); // 验证强密码

        passwordList.forEach(password -> {
            System.out.println("[" + password + "] -> " + check(password));
        });
    }

}

@Data
@NoArgsConstructor
@AllArgsConstructor
class StringCounter{

    private int number; // 数字出现的次数
    private int smallLetter; // 小写字母出现的次数
    private int bigLetter; // 大写字母出现的次数
    private int symbol; // 特殊符号出现的次数

    public StringCounter initInstance(String s){
        if (Utils.isNullOrEmpty(s)){
            return new StringCounter(0, 0, 0, 0);
        }else {
            char[] chars = s.toCharArray();
            int number = 0, smallLetter = 0, bigLetter = 0, symbol = 0;
            for (char c : chars) {
                if (c > 47 && c < 58){
                    number++;
                } else if(c > 64 && c < 91){
                    bigLetter++;
                } else if(c > 96 && c < 123){
                    smallLetter++;
                } else {
                    symbol++;
                }
            }
            return new StringCounter(number, smallLetter, bigLetter, symbol);
        }
    }

    public int getKinds(){
        int kinds = 0;
        if (this.number > 0) kinds++;
        if (this.smallLetter > 0) kinds++;
        if (this.bigLetter > 0) kinds++;
        if (this.symbol > 0) kinds++;
        return kinds;
    }

}

main函数输出:

[null] -> false
[] -> false
[123456] -> false
[lps123456] -> false
[Lps123456] -> true
[Lps*20210831*] -> true

Process finished with exit code 0
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Spring Boot 中,可以使用 Hibernate Validator 来进行请求参数校验。具体步骤如下: 1. 引入 Hibernate Validator 依赖: ```xml <dependency> <groupId>org.hibernate.validator</groupId> <artifactId>hibernate-validator</artifactId> <version>6.1.5.Final</version> </dependency> ``` 2. 在需要校验的请求参数实体类中添加校验注解,例如: ```java public class User { @NotBlank(message = "用户名不能为空") private String username; @NotBlank(message = "密码不能为空") private String password; @Email(message = "邮箱格式不正确") private String email; // 省略 getter 和 setter 方法 } ``` 3. 在请求处理方法中添加 @Validated 注解,并在参数上添加 @Valid 注解,例如: ```java @RestController @RequestMapping("/user") @Validated public class UserController { @PostMapping("/login") public Result login(@RequestBody @Valid User user) { // 处理登录逻辑 } } ``` 4. 当请求参数不符合校验规则时,会抛出 ConstraintViolationException 异常。可以在全局异常处理器中对该异常进行处理,例如: ```java @RestControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(ConstraintViolationException.class) public Result handleConstraintViolationException(ConstraintViolationException e) { List<String> errorMessages = e.getConstraintViolations().stream() .map(ConstraintViolation::getMessage) .collect(Collectors.toList()); return Result.error(String.join(",", errorMessages)); } } ``` 这样就可以自定义请求参数校验了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

遥夜人间

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值