Springboot+MybatisPlus如何实现带验证码的登录功能

发布于:2024-05-16 ⋅ 阅读:(54) ⋅ 点赞:(0)

实现带验证码的登录功能由两部分组成::1、验证码的获取   2、登录(进行用户名、密码和验证码的判断)

获取验证码

获取验证码需要使用HuTool中的CaptchaUtil.createLineCaptcha()来定义验证码的长度、宽度、验证码位数以及干扰线条数

同时也要使用到HttpSession对象和HeepServletResponse对象  session:拿到验证码需要放入session中,response用来返回页面

1、获取验证码对象

LineCaptcha linCaptcha=CaprchaUtil.createLineCaptcha(116,40,4,10);

2、放入session

session.setAttribute("code",lineCaptcha.getCode);

3、输出

ServletOutputStream stream=response.getOutputStream();
lineCaptcha.write(stream);

4、关闭

stream.close();

登录

登录功能首先要去判断验证码,若验证码为空或者不匹配,直接返回错误;否则再去进行用户名和密码的对比

1、判断验证码

String sessioncode=(String)session.getAttribute("code");
if(code!=null && code.equals(sessioncode)
{

}

2、若验证码存在并且象征吗匹配成功则去数据库比对用户名和密码(这里我们需要创建一个新的sql语句 select * from user where username=#{username} &&  password=#{password})如何去创建一个新的sql语句请查看http://t.csdnimg.cn/y7rWT


String sessioncode=(String)session.getAttribute("code");
if(code!=null && code.equals(sessioncode)
{
   User user=userService.login(username,password);
   if(user!=null)
   {
      //登录成功
      session.setAttribute("user",user);
   }
   else
   {  //登录失败,用户名或密码有误}
}
else
{  //登录失败,验证码有误}

     

 创建一个新的sql语句 userService.login(username,password)

(1)Mapper中

@Select("select * from user where username=#{uesrname} && password=#{password}
public User login(String username,String password);

 (2)Service中

public User login(Sting username,String password);

 (3)ServiceImpl中

@Autowird 
UserMapper userMapper

@Overried
public User login(String username,String password)
{
   return userMapper.login(username,password);
}