今天依旧学习了黑马的瑞吉外卖,以下是我跟着视频学习写的代码,关于用户登录验证和退出:
/** * 员工登录 * @param employee * @param request * @return */ @PostMapping("/login") public R<Employee> login(@RequestBody Employee employee, HttpServletRequest request){ //1.将页面提交的密码password进行MD5加密处理 String password = employee.getPassword(); password = DigestUtils.md5DigestAsHex(password.getBytes()); //2.根据页面提交的用户名username查询数据库 LambdaQueryWrapper<Employee> lqw = new LambdaQueryWrapper<>(); lqw.eq(Strings.isNotEmpty(employee.getUsername()),Employee::getUsername,employee.getUsername()); Employee emp = employeeService.getOne(lqw); //3.如果没有查询到则返回登陆失败结果 if(emp == null){ return R.error("登录失败"); } //4.密码比对,如果不一致则返回登陆失败结果 if(!emp.getPassword().equals(password)){ return R.error("登录失败"); } //5.查看员工状态,如果为已禁用状态,则返回员工已禁用结果 if(emp.getStatus() == 0){ return R.error("账号已禁用"); } //6.登录成功,将员工id存入session并返回登陆成功结果 HttpSession session = request.getSession(); session.setAttribute("employee",emp.getId()); return R.success(emp); }
/** * 员工退出 * @param request * @return */ @PostMapping("/logout") public R<String> logout(HttpServletRequest request){ //清除Session中保存的当前员工的id request.getSession().removeAttribute("employee"); return R.success("退出成功"); }
欢迎大家一起学习,有不足的地方还请指出。