|  |  |  | 
|---|
|  |  |  | // 查询用户是否存在 | 
|---|
|  |  |  | R<LoginUserInfoVO> r = userService.getUserInfo(userName); | 
|---|
|  |  |  | if (r.getCode()!=200) { | 
|---|
|  |  |  | throw new UsernameNotFoundException("用户名不存在"); | 
|---|
|  |  |  | throw new UsernameNotFoundException("该账号不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | LoginUserInfoVO loginUserInfoVO = r.getData(); | 
|---|
|  |  |  | List<GrantedAuthority> grantedAuthorityList=new ArrayList<>(); | 
|---|
|  |  |  | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (ObjectUtils.isEmpty(loginUserInfoVO.getAccount())) { | 
|---|
|  |  |  | throw new UsernameNotFoundException("用户名不存在"); | 
|---|
|  |  |  | throw new UsernameNotFoundException("该账号不存在"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 我们还要判断密码是否正确,这里我们的密码使用BCryptPasswordEncoder进行加密的 | 
|---|
|  |  |  | if (!new BCryptPasswordEncoder().matches(password, loginUserInfoVO.getPassword())) { | 
|---|
|  |  |  | 
|---|
|  |  |  | if (loginUserInfoVO.getStatus().intValue()==2) { | 
|---|
|  |  |  | throw new LockedException("该用户已被禁用"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        维护最后登录时间 | 
|---|
|  |  |  | userService.putUserLastLoginTime(loginUserInfoVO.getUserId()); | 
|---|
|  |  |  | return new UsernamePasswordAuthenticationToken(loginUserInfoVO, password, grantedAuthorityList); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|