【Javaweb】【瑞吉外卖】登录功能plus--拦截器filter&interceptors实现

上手第二天,做到登录拦截器部分

需求:完成目标是,只有在登录的情况下才想让其访问后端,没有登录禁止访问,并且让其跳转。
这里有一个比较好的思想是:后端程序要主要需要考虑的是拦截接口,不能让数据接口能够让没有未被登录的用户进行访问,而前端页面不用去管,交给前端程序员去操作
[前端dalao:我TM蟹蟹你啊哈哈哈^_^]。

解决方式:

第一种方法,按照黑马的方式,添加filter

所需要的大概过程:

  1. 编写类,需要实现servlet下的filter接口
  2. 需要重写doFilter方法。
  3. 方法内写逻辑
  4. 代码里面细说
@Slf4j
//spring注入编写的注解
// 第一个参数名字而已,随便,第二个参数表示需要拦截的url
@WebFilter(filterName = "loginCheckFilter", urlPatterns = "/*")
public class LoginCheckFilter implements Filter {

	// 这个用来进行检测通配符的
    private static final AntPathMatcher PATH_MATCHER = new AntPathMatcher();

	
    /**
     * 需要重写的doFilter方法
     * @param servletRequest    本次访问的req请求
     * @param servletResponse   本次需要会送的res
     * @param filterChain       这个好像就是传送给下一个filter的内容
     * @throws IOException
     * @throws ServletException
     */
    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        // 首先需要强转一下
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        log.info("拦截到请求:{}", request.getRequestURI());
        // filterChain.doFilter(request, response);

        // 1. 获取本次req的URI
        String uri = request.getRequestURI();

        // 直接放行的接口
        String[] strs = new String[]{
                "/employee/login",
                "/employee/logout",
                "/backend/**",
                "/front/**"
        };

        // 2. 判断本次是否需要处理
        if (checkUri(strs, uri)){
            // 这么写就表示这一层filter通过,再交给下一个filter进行检验
            // 如果都没有了就正常访问controller
            // 也只是我这么猜的
            filterChain.doFilter(request, response);
            return;
        }
        // 3. 如果不需要处理直接放行
        // 4. 判断是否已经登录,如果登录放行
        if (request.getSession().getAttribute("employee") != null) {
            filterChain.doFilter(request, response);
            return;
        }
        // 5. 未登录拦截,并且返回信号
        response.getWriter().write(JSON.toJSONString(R.error("NOTLOGIN")));

    }

    private boolean checkUri(String[] urls, String reqUri){
        for (String url : urls) {
            // 因为url有用到通配符,需要用这个match匹配一下
            // 满足true,反之false
            if (PATH_MATCHER.match(url, reqUri))
                return true;
        }
        return false;
    }
}

第二种方法,编写interceptor类进行拦截

弹幕大神里面说拦截器方法没几行的事,所以我就深入学习一下。
主要参考(chao xi)的博客: https://blog.csdn.net/Herishwater/article/details/103544342

这位dalao写的很详细,插眼瞅瞅。

主要写如何实现拦截器功能,功能强大,看楼上这个大佬的解析。

实现步骤:

  1. 编写Interceptor类,实现HandlerInterceptor这个接口
  2. 重写里面三个方法,因为实现拦截器,主要关注的是preHandle这个方法
  3. 其他两个可以暂时不用管
  4. 去config类里面重写一个addInterceptors
  5. 注册一下刚刚写的类,并且添加一下拦截路径就行

目前可以察觉到明显的好处:

  1. req, res不需要强转
  2. 添加的pattern可以直接用通配符,直接疯狂add就行,不需要自己写if
  3. 功能更强大,主要看另外两个方法
@Slf4j
public class LoginInterceptor implements HandlerInterceptor {

    /**
     * 这个类是在处理controller之前执行的,实行时间有点类似于filter
     * @param request       参数也比较类似,但这两个都是httpServlet,所以不用强转
     * @param response
     * @param handler
     * @return
     * @throws Exception
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

        log.info("拦截到请求: {}", request.getRequestURI());

        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {

    }

    @Override
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {

    }
}

	// config类下面重写这个方法,注册一下刚刚写的interceptor
    @Override
    protected void addInterceptors(InterceptorRegistry registry) {
		// 注册
		// 并且添加一下需要拦截的路径,这里可以直接用通配符,不需要进行额外检测
		// 这里一个*代表当前目录下所有文件但非递归,两个**代表递归
        registry.addInterceptor(new LoginInterceptor()).addPathPatterns("/backend/**");
    }

还有弹幕大佬说用jwt做,到时候看看(挖个坑)

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是JavaWeb实现自动登录和filter辅助登录的具体代码: 1. 实现自动登录 在用户登录时,生成包含用户信息的cookie,并发送给客户端浏览器,代码如下: ```java // 用户登录成功后,生成cookie Cookie cookie = new Cookie("username", URLEncoder.encode(username, "utf-8")); cookie.setMaxAge(7 * 24 * 60 * 60); // 设置cookie过期时间为一周 response.addCookie(cookie); // 发送cookie到客户端浏览器 ``` 在用户访问网站时,检查cookie是否存在,如果存在,则直接登录,代码如下: ```java // 检查cookie是否存在 Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if (cookie.getName().equals("username")) { String username = URLDecoder.decode(cookie.getValue(), "utf-8"); // 根据cookie中的用户名查询用户信息,如果存在则直接登录 // ... } } } ``` 2. 实现filter辅助登录 在filter中,检查用户是否已经登录,如果没有登录,则重定向到登录页面,代码如下: ```java public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse resp = (HttpServletResponse) response; HttpSession session = req.getSession(); if (session.getAttribute("user") == null) { // 用户未登录,重定向到登录页面 resp.sendRedirect(req.getContextPath() + "/login.jsp"); } else { // 用户已登录,继续处理当前请求 chain.doFilter(request, response); } } ``` 在登录成功后,将用户信息保存到session中,代码如下: ```java // 用户登录成功,将用户信息保存到session中 HttpSession session = request.getSession(); session.setAttribute("user", user); ``` 在需要辅助登录的页面上,添加filter的配置,代码如下: ```xml <filter> <filter-name>LoginFilter</filter-name> <filter-class>com.example.filter.LoginFilter</filter-class> </filter> <filter-mapping> <filter-name>LoginFilter</filter-name> <url-pattern>/admin/*</url-pattern> <!-- 拦截/admin目录下的所有请求 --> </filter-mapping> ``` 以上是JavaWeb实现自动登录和filter辅助登录的示例代码,具体实现还需要根据实际情况进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值