Web后端登录功能实现

Web后端登录功能实现

思路:

  • 使用前端传入的用户名去查询该用户名是否存在
    • 不存在,抛出异常并返回登录页面
    • 存在,用该用户名查询出User数据
      • 将前端传入的密码进行一次MD5加密
      • 使用加密后的密码与User中的密码比较
        • 如果密码不一致,抛出异常并返回到登录页面
        • 密码一致,登录成功,将User保存到Session域中

代码实现

Controller层
/**
    * @Author: yzh
    * @Description: 用户登录功能
    * @Param: [username, password, session]
    * @return: java.lang.String
    * @Date: 2021/8/13
    */
    @RequestMapping("login")
    public String login(String username,String password,HttpSession session) throws UnsupportedEncodingException {
   
        log.debug("接收到用户名:{}, 接收到密码:{}",username,password);
        try {
   
            //1.执行登录业务逻辑
            User user = userService.login(username,password);
            //2.登录成功,保存用户登录标记
            session.setAttribute("user",user);
        } catch (Exception e) {
   
            e.printStackTrace();
            return "redirect:/login.jsp?msg="+URLEncoder.encode(e.getMessage(),"UTF-8");
        }
        return "redirect:/employee/list";
    }
Service层
 /**
    * @Author: yzh
    * @Description: 用户登录
    * @Param: [username, password]
    * @return: User
    * @Date: 2021/8/13
    */  
    @Override
    public User login(String username, String password) {
   
        //1.根据用户输入用户名查询数据中是否存在
        User user = userDao.findByUserName(username);
        //2.判断对象是否存在
        if (ObjectUtils.isEmpty(user)) throw new RuntimeException("用户名输入错误!")
  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值