关于Spring Security如何自定义的异常

本文记录了在使用Spring Security时遇到的自定义异常问题。由于必须让自定义异常LoginAccessException继承AccessDeniedException,而直接抛出UsernameNotFoundException会导致错误信息显示为'Bad credentials'。通过创建自己的异常类并正确配置,可以解决异常信息不一致的问题,以此避免未来的错误重复。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于Spring Security如何工作原理在这里就不介绍了。因为我也不懂

@Override
	public UserDetails loadUserByUsername(String mobile) throws UsernameNotFoundException {
		String[] str = mobile.split(BusinessConstant.Constants.KEY_SPLIT_SYMBOL_2);
		if(null == str) {
			throw new LoginAccessException("请输入用户名");
		} else if(1 == str.length) {
			throw new LoginAccessException("请输入用户名不存在");
		} else if(str.length > 2) {
			throw new LoginAccessException("输入用户名不合法,请不要输入非法字符");
		}
		UserInfo record = userInfoMapper.findBymobile(str[0], str[1]);
		if (record == null) {
			throw new LoginAccessException("该用户不存在");
		} else if(record.getStatus() != 1) {
			throw new LoginAccessException("该用户已被禁用, 请联系管理员");
//			throw new UsernameNotFoundException("该用户已不是正常状态, 请联系管理员");
		}
		List<GrantedAuthority> authorities=new ArrayList<>();
		try {
			//权限如果
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值