若依框架深度学习

登录模块

验证码

采用的base64加密处理,我们通过响应结果查看验证码图片是我们需要加上
登录模块
验证码
采用的base64加密处理,我们通过响应结果查看验证码图片是我们需要加上

data:image/png;base64,才能看见效果,具体如下



验证码实在后台生成的,我们会验证码的生成信息以及结果存储到redis缓存中,在保存验证码信息的时候,会给它加上一个uuid

 /**
     * 验证码 redis key
     */
    public static final String CAPTCHA_CODE_KEY = "captcha_codes:";
  // 保存验证码信息
        String uuid = IdUtils.simpleUUID();
        String verifyKey = Constants.CAPTCHA_CODE_KEY + uuid;

验证码后台生成并且存入redis

  String capText = captchaProducerMath.createText();
  capStr = capText.substring(0, capText.lastIndexOf("@"));
  code = capText.substring(capText.lastIndexOf("@") + 1);
  
   redisCache.setCacheObject(verifyKey, code, Constants.CAPTCHA_EXPIRATION, TimeUnit.MINUTES);

最后将生成的验证码信息通过流传给前端,并且进行对图片进行了加密处理

FastByteArrayOutputStream os = new FastByteArrayOutputStream();
        try
        {
            ImageIO.write(image, "jpg", os);
        }
        catch (IOException e)
        {
            return AjaxResult.error(e.getMessage());
        }

        ajax.put("uuid", uuid);
        ajax.put("img", Base64.encode(os.toByteArray()));

验证码生成之后,前台会接收到一个图片的信息和uuid,当我们讲用户名和密码填写好了之后我们会根据uuidredis中找到键根然后获取对应的缓存中验证码的值,进行对比看看是否正确,具体流程图如下:
在这里插入图片描述
具体的登录逻辑的实现我们可以通过前端发起的请求地址找到,也可以看见前端传过来的具体参数信息

http://localhost/dev-api/login

参数信息

{username: "admin", password: "admin123", code: "3", uuid: "dcb06362103d4f3889ff171c95787779"}
code: "3"
password: "admin123"
username: "admin"
uuid: "dcb06362103d4f3889ff171c95787779"

因为这个认证部分是使用springSecurity来做的首先会通过authenticate该方法会去调用UserDetailsServiceImpl.loadUserByUsername,最后若依后台重写了loadUserByUsername这个方法,最后通过用户名去数据库中进行查询,并返回响应结果

   // 该方法会去调用UserDetailsServiceImpl.loadUserByUsername
            authentication = authenticationManager
                    .authenticate(new UsernamePasswordAuthenticationToken(username, password));

通过debug主要调用过程如下
在这里插入图片描述
最后若依框架重写了UserDetailsService.loadUserByUsername()方法

/**
 * 用户验证处理
 *
 * @author ruoyi
 */
@Service
public class UserDetailsServiceImpl implements UserDetailsService
{
    private static final Logger log = LoggerFactory.getLogger(UserDetailsServiceImpl.class);

    @Autowired
    private ISysUserService userService;

    @Autowired
    private SysPermissionService permissionService;

    @Override
    public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException
    {
        SysUser user = userService.selectUserByUserName(username);
        if (StringUtils.isNull(user))
        {
            log.info("登录用户:{} 不存在.", username);
            throw new ServiceException("登录用户:" + username + " 不存在");
        }
        else if (UserStatus.DELETED.getCode().equals(user.getDelFlag()))
        {
            log.info("登录用户:{} 已被删除.", username);
            throw new ServiceException("对不起,您的账号:" + username + " 已被删除");
        }
        else if (UserStatus.DISABLE.getCode().equals(user.getStatus()))
        {
            log.info("登录用户:{} 已被停用.", username);
            throw new ServiceException("对不起,您的账号:" + username + " 已停用");
        }

        return createLoginUser(user);
    }

    public UserDetails createLoginUser(SysUser user)
    {
        return new LoginUser(user.getUserId(), user.getDeptId(), user, permissionService.getMenuPermission(user));
    }
}

通过用户名查询出来用户,在通过我们传入的密码进行比对,具体逻辑如下

protected void additionalAuthenticationChecks(UserDetails userDetails, UsernamePasswordAuthenticationToken authentication) throws AuthenticationException {
        if (authentication.getCredentials() == null) {
            this.logger.debug("Failed to authenticate since no credentials provided");
            throw new BadCredentialsException(this.messages.getMessage("AbstractUserDetailsAuthenticationProvider.badCredentials", "Bad credentials"));
        } else {
            String presentedPassword = authentication.getCredentials().toString();
            if (!this.passwordEncoder.matches(presentedPassword, userDetails.getPassword())) {
                this.logger.debug("Failed to authenticate since password does not match stored value");
                throw new BadCredentialsException(this.messages.getMessage("AbstractUserDetailsAuthenticationProvider.badCredentials", "Bad credentials"));
            }
        }
    }

最后返回前端登录信息成功与否的结果

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值