第10讲用户登录SpringSecurity查库实现

用户登录SpringSecurity查库实现

security包下新建MyUserDetailServiceImpl

bash 复制代码
@Service
public class MyUserDetailServiceImpl implements UserDetailsService {

    @Autowired
    SysUserService sysUserService;

    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
        SysUser sysUser = sysUserService.getByUsername(username);
        if(sysUser==null){
            throw new UsernameNotFoundException("用户名或者密码错误!");
        }else if("1".equals(sysUser.getStatus())){
            throw new UserCountLockException("该用户账号已被封禁,具体联系管理员!");
        }
        return new User(sysUser.getUsername(),sysUser.getPassword(),getUserAuthority(sysUser.getId()));
    }

    private List<GrantedAuthority> getUserAuthority(Long id) {
        return new ArrayList<>();
    }
}

getByUsername实现:

bash 复制代码
@Service
public class SysUserServiceImpl extends ServiceImpl<SysUserMapper, SysUser>
    implements SysUserService{


    @Override
    public SysUser getByUsername(String username) {
        return getOne(new QueryWrapper<SysUser>().eq("username",username));
    }
}

SecurityConfig配置类里面配置下MyUserDetailServiceImpl


配置下默认加密bean

bash 复制代码
@Bean
BCryptPasswordEncoder bCryptPasswordEncoder(){
    return new BCryptPasswordEncoder();
}

自定义异常UserCountLockException

bash 复制代码
public class UserCountLockException extends AuthenticationException {

    public UserCountLockException(String msg, Throwable t) {
        super(msg, t);
    }

    public UserCountLockException(String msg) {
        super(msg);
    }
}

全局异常GlobalExceptionHandler:

bash 复制代码
@Slf4j
@RestControllerAdvice
public class GlobalExceptionHandler {

    @ExceptionHandler(value = RuntimeException.class)
    public R handler(RuntimeException e){
        log.error("运行时异常:----------------{}", e.getMessage());
        System.out.println("运行时异常:");
        return R.error(e.getMessage());
    }
    
}
相关推荐
天天向上10243 分钟前
Vue 配置一次打包执行多个命令,并将分别输出到不同的文件夹
前端·javascript·vue.js
BD_Marathon8 分钟前
【JavaWeb】HTML——超链接标签
前端·html
彭于晏爱编程13 分钟前
🐻 Zustand 使用指南:从 0 到精通的最快路线
前端
장숙혜13 分钟前
Vue DevTools 速通-掌握开发调试器
前端·javascript·vue.js
谢尔登17 分钟前
为什么React 17开始无需在组件中引入React了?
前端·react.js·前端框架
ohyeah18 分钟前
JavaScript 面向对象的本质:从对象模板到组合继承的完整演进
前端·javascript
Drift_Dream24 分钟前
虚拟滚动:优化长列表性能的利器
前端
逃离疯人院24 分钟前
前端性能深度解析:网络响应时间与实际渲染时间的鸿沟
前端
我是若尘34 分钟前
🚀 深入理解 Claude Code:从入门到精通的能力全景图
前端
老前端的功夫42 分钟前
Webpack 深度解析:从配置哲学到编译原理
前端·webpack·前端框架·node.js