栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何读取和复制HTTP Servlet响应输出流内容以进行日志记录

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何读取和复制HTTP Servlet响应输出流内容以进行日志记录

你需要创建一个,在

Filter
其中
ServletResponse
用自定义
HttpServletResponseWrapper
实现包装参数,在其中覆盖
getOutputStream()
getWriter()
并返回一个自定义
ServletOutputStream
实现,在该实现中你将写入的字节复制到基本抽象
OutputStream#write(int b)
方法中。然后,你将包装的自定义传递
HttpServletResponseWrapper
FilterChain#doFilter()
调用,最后,你应该能够在调用之后获得复制的响应。

换句话说Filter:

@WebFilter("/*")public class ResponseLogger implements Filter {    @Override    public void init(FilterConfig config) throws ServletException {        // NOOP.    }    @Override    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {        if (response.getCharacterEncoding() == null) { response.setCharacterEncoding("UTF-8"); // Or whatever default. UTF-8 is good for World Domination.        }        HttpServletResponseCopier responseCopier = new HttpServletResponseCopier((HttpServletResponse) response);        try { chain.doFilter(request, responseCopier); responseCopier.flushBuffer();        } finally { byte[] copy = responseCopier.getCopy(); System.out.println(new String(copy, response.getCharacterEncoding())); // Do your logging job here. This is just a basic example.        }    }    @Override    public void destroy() {        // NOOP.    }}

习惯HttpServletResponseWrapper:

public class HttpServletResponseCopier extends HttpServletResponseWrapper {    private ServletOutputStream outputStream;    private PrintWriter writer;    private ServletOutputStreamCopier copier;    public HttpServletResponseCopier(HttpServletResponse response) throws IOException {        super(response);    }    @Override    public ServletOutputStream getOutputStream() throws IOException {        if (writer != null) { throw new IllegalStateException("getWriter() has already been called on this response.");        }        if (outputStream == null) { outputStream = getResponse().getOutputStream(); copier = new ServletOutputStreamCopier(outputStream);        }        return copier;    }    @Override    public PrintWriter getWriter() throws IOException {        if (outputStream != null) { throw new IllegalStateException("getOutputStream() has already been called on this response.");        }        if (writer == null) { copier = new ServletOutputStreamCopier(getResponse().getOutputStream()); writer = new PrintWriter(new OutputStreamWriter(copier, getResponse().getCharacterEncoding()), true);        }        return writer;    }    @Override    public void flushBuffer() throws IOException {        if (writer != null) { writer.flush();        } else if (outputStream != null) { copier.flush();        }    }    public byte[] getCopy() {        if (copier != null) { return copier.getCopy();        } else { return new byte[0];        }    }}

习惯ServletOutputStream:

public class ServletOutputStreamCopier extends ServletOutputStream {    private OutputStream outputStream;    private ByteArrayOutputStream copy;    public ServletOutputStreamCopier(OutputStream outputStream) {        this.outputStream = outputStream;        this.copy = new ByteArrayOutputStream(1024);    }    @Override    public void write(int b) throws IOException {        outputStream.write(b);        copy.write(b);    }    public byte[] getCopy() {        return copy.toByteArray();    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/363717.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号