其他分享
首页 > 其他分享> > 拦截器

拦截器

作者:互联网

 

 

InterceptorConfig代码
package com.xt.cn.springboot.interceptor.config;


import com.xt.cn.springboot.interceptor.interceptor.LogCostInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@Configuration
public class InterceptorConfig extends WebMvcConfigurerAdapter{

    @Override
    public void addInterceptors(InterceptorRegistry registry){
        //registry.addInterceptor(new LogCostInterceptor()).addPathPatterns("/**");
        registry.addInterceptor(new LogCostInterceptor()).addPathPatterns("/test1");
        registry.addInterceptor(new LogCostInterceptor()).addPathPatterns("/test2");
        super.addInterceptors(registry);
    }
}

 

LogCostInterceptor代码
package com.xt.cn.springboot.interceptor.interceptor;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.PrintWriter;
import java.util.Enumeration;

public class LogCostInterceptor implements HandlerInterceptor {
    long start = System.currentTimeMillis();

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        /*HttpSession session = request.getSession();
        session.setAttribute("user","zhangsan");
        session.setAttribute("pwd",123456);

        Enumeration<String> attributeNames = session.getAttributeNames();
        while (attributeNames.hasMoreElements()){
            String k = attributeNames.nextElement();
            System.out.println(k+"--"+session.getAttribute(k));
        }*/

        String userName = request.getParameter("username");
        System.out.println("请求执行之前:userName="+userName + "111");

        return true;
    }

    @Override
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        String userName = request.getParameter("username");
        System.out.println("请求执行之后:userName="+userName + "222");
    }

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

    }
}

  

Test1Controller代码
package com.xt.cn.springboot.interceptor.controller;

import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;

@RestController
public class Test1Controller {

    @GetMapping("/test1")
    public String test(HttpServletRequest request, String username) {
        System.out.println("controller中username=" + username);
        System.out.println("请求头中的Cookie信息:" + request.getHeader("Cookie"));
        return "123";
    }

    @GetMapping("/test2")
    public String test2(HttpServletRequest request) {
        return "123";
    }
}

  

 

 

 

 

 

 

标签:HttpServletRequest,拦截器,request,import,interceptor,servlet,public
来源: https://www.cnblogs.com/ixtao/p/16485963.html