Java精品项目瑞吉外卖之登陆的完善与退出功能篇
上一篇:
一. 需求分析
员工登录之后,页面跳转到后台首页(backend/index.html)此前会显示用户登录的用户名,点击退出按钮退出系统。
请求API:
说明 | 值 |
请求地址URL | employee/loginout |
请求参数 | 无 |
返回参数 | ({ "code": 1, "msg": null, "data": "退出成功", "map": {} } |
二.功能实现
只需要清除session即可,在controller中添加如下代码:
/** * 后管登出 * @param request * @return */ @PostMapping("/logout") public R<String> loginOut(HttpServletRequest request){ // 去除session request.getSession().removeAttribute("employee"); return R.success("退出成功"); }
三.功能测试
登录成功后是有session记录的:
点击页码按钮退出后session清除,并返回登录页面就表示成功了。
四. 登录功能完善
4.1 问题分析
前面已经完成了登录功能的开发,但会发现一个问题,就是员工不登录情况下,依然能够进入到目标页面很显然这并不是我们想看到的。
那如何实现呢?使用过滤器或者拦截器,在过滤器或者拦截器中判断用户是否是登录状态,没有登录则跳转到登录页面。
4.2 实现步骤
- 创建自定义过滤器LoginCheckFilter.java
- 启动类上加入@ServletComponentScan(这个不要忘记了)
- 完善过滤器处理逻辑
过滤器处理逻辑主要如下:
- 获取本次处理请求的URL
- 判断本次请求是否需要处理
- 若不需要,直接放行
- 判断登陆状态,若已经登陆直接放行
- 若未登陆则返回未登陆结果
流程图如下:
4.3 代码实现
package com.itheima.reggie.filter; import com.alibaba.fastjson.JSON; import com.itheima.reggie.common.R; import lombok.extern.slf4j.Slf4j; import org.springframework.util.AntPathMatcher; import javax.servlet.*; import javax.servlet.annotation.WebFilter; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; /** * @author jektong * @date 2022/4/26 */ @WebFilter(filterName = "loginCheckFilter", urlPatterns = "/*") @Slf4j public class LoginCheckFilter implements Filter { // 进行路径匹配,支持通配符 public static final AntPathMatcher ANT_PATH_MATCHER = new AntPathMatcher(); @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { HttpServletRequest request = (HttpServletRequest) servletRequest; HttpServletResponse response = (HttpServletResponse) servletResponse; //获取本次处理请求的URL String requestURI = request.getRequestURI(); String[] urls = new String[]{ "/employee/login", "/employee/logout", "/backend/**", "/front/**" }; //判断本次请求是否需要处理 boolean check = this.check(urls, requestURI); log.info("拦截到请求:{}", requestURI); //若不需要,直接放行 if (check){ log.info("请求无需登录:{}", requestURI); filterChain.doFilter(request,response); return; } //判断登陆状态,若已经登陆直接放行 if(request.getSession().getAttribute("employee") != null){ log.info("用户已登录,id为:{}", request.getSession().getAttribute("employee")); filterChain.doFilter(request,response); return; } //若未登陆则返回未登陆结果 response.getWriter().write(JSON.toJSONString(R.error("NOTLOGIN"))); return; } /** * 进行路径匹配,检查是否可以放行 * @param urls 不拦截的路径 * @param requestURI 请求路径 * @return */ public boolean check(String[] urls, String requestURI) { for(String url : urls){ boolean match = ANT_PATH_MATCHER.match(url,requestURI); if(match){ return true; } } return false; } }
前端代码(request.js)会通过一个值("NOTLOGIN")来进行拦截器响应匹配后进行页面的跳转:
// 响应拦截器 service.interceptors.response.use(res => { if (res.data.code === 0 && res.data.msg === 'NOTLOGIN') {// 返回登录页面 console.log('---/backend/page/login/login.html---') localStorage.removeItem('userInfo') window.top.location.href = '/backend/page/login/login.html' } else { return res.data } }
到此这篇关于Java精品项目瑞吉外卖之登陆的完善与退出功能篇的文章就介绍到这了,更多相关Java外卖系统登陆内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Java lombok中@Accessors注解三个属性的作用
这篇文章主要介绍了Java lombok的@Accessors注解属性解析,该注解主要作用是:当属性字段在生成 getter 和 setter 方法时,做一些相关的设置,需要的朋友可以参考下2023-05-05解决Mybatis-plus和pagehelper依赖冲突的方法示例
这篇文章主要介绍了解决Mybatis-plus和pagehelper依赖冲突的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2021-04-04Spring Boot前后端分离开发模式中的跨域问题及解决方法
本文介绍了解决Spring Boot前端Vue跨域问题的实战经验,并提供了后端和前端的配置示例,通过配置后端和前端,我们可以轻松解决跨域问题,实现正常的前后端交互,需要的朋友可以参考下2023-09-09
最新评论