拦截请求(request)和响应(response)信息

思路

  1. 使用拦截器;
  2. 使用Filter;

实现

  1. 使用拦截器时不能获取到返回的信息(response里的content为空);
  2. 使用Filter,成功获取到内容:
@WebFilter(urlPatterns = "/*")
public class GlobalFilter implements Filter {
    private Logger logger = LoggerFactory.getLogger(GlobalFilter.class);

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    /**
     * 拦截请求和相应信息,并保存到数据库中
     */
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        WkResponseWrapper wrapper = new WkResponseWrapper((HttpServletResponse)response);
        ContentCachingRequestWrapper requestWrapper = new ContentCachingRequestWrapper((HttpServletRequest) request);
        HttpServletRequest req = (HttpServletRequest) request;
        String params = "";

        try {

            chain.doFilter(requestWrapper, wrapper);
            String responseContent = new String(wrapper.getDataStream());

            String method = req.getMethod();
            if ("POST".equalsIgnoreCase(method)) {
                params = new String(requestWrapper.getContentAsByteArray());
            } else if ("GET".equalsIgnoreCase(method)) {
                params = JSON.toJSONString(request.getParameterMap());
            }

            response.getWriter().write(responseContent);


        } catch (Exception e) {
            logger.error("保存请求和相应信息时出现异常:", e);
        }
    }

    @Override
    public void destroy() {

    }


}

public class WkResponseWrapper  extends HttpServletResponseWrapper {
    ByteArrayOutputStream output;
    FilterServletOutputStream filterOutput;

    public WkResponseWrapper(HttpServletResponse response) {
        super(response);
        output = new ByteArrayOutputStream();
    }

    @Override
    public ServletOutputStream getOutputStream() throws IOException {
        if (filterOutput == null) {
            filterOutput = new FilterServletOutputStream(output);
        }
        return filterOutput;
    }

    public byte[] getDataStream() {
        return output.toByteArray();
    }


    class FilterServletOutputStream extends ServletOutputStream {
        DataOutputStream output;

        public FilterServletOutputStream(OutputStream output) {
            this.output = new DataOutputStream(output);
        }

        @Override
        public void write(int arg0) throws IOException {
            output.write(arg0);
        }

        @Override
        public void write(byte[] arg0, int arg1, int arg2) throws IOException {
            output.write(arg0, arg1, arg2);
        }

        @Override
        public void write(byte[] arg0) throws IOException {
            output.write(arg0);
        }

        @Override
        public boolean isReady() {
            return false;
        }

        @Override
        public void setWriteListener(WriteListener writeListener) {

        }
    }
}
好的,可以为您详细讲解一下如何在request封装中添加请求拦截响应拦截。 首先,需要使用axios来封装请求。axios是一个基于Promise的HTTP库,可以用于浏览器和Node.js。在使用axios时,可以通过创建axios实例来对请求进行拦截响应拦截。 以下是一个示例代码,展示如何在请求封装中添加请求拦截响应拦截: ```javascript import axios from 'axios'; const instance = axios.create({ baseURL: 'http://api.example.com', timeout: 1000, headers: {'X-Custom-Header': 'foobar'} }); // 添加请求拦截器 instance.interceptors.request.use(function (config) { // 在发送请求之前做些什么 return config; }, function (error) { // 对请求错误做些什么 return Promise.reject(error); }); // 添加响应拦截器 instance.interceptors.response.use(function (response) { // 对响应数据做些什么 return response; }, function (error) { // 对响应错误做些什么 return Promise.reject(error); }); export default instance; ``` 在这个示例中,我们创建了一个axios实例,并使用instance.interceptors.request.use()方法来添加请求拦截器,使用instance.interceptors.response.use()方法来添加响应拦截器。在请求拦截器中,可以对请求进行一些处理,例如添加请求信息、验证用户身份等。在响应拦截器中,可以对响应进行一些处理,例如处理错误信息、统一格式化响应数据等。 值得注意的是,如果需要在多个请求中使用相同的拦截器,可以将拦截器封装成一个函数或者一个模块,然后在需要使用的地方引入。这样可以提高代码的复用性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值