拦截请求(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) {

        }
    }
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值