HTTP 서블릿 응답 콘텐츠를 캡처하고 기록하는 방법
소개
요청 및 기록 모두 기록 응답 콘텐츠는 포괄적인 서버 측 디버깅 및 모니터링에 필수적입니다. 필터를 통해 요청 매개변수에 액세스하는 것은 간단하지만 응답 콘텐츠를 검색하는 것은 더 어려울 수 있습니다. 이 기사에서는 로깅 목적으로 서블릿 응답을 가로채서 복사하는 필터를 생성하는 방법을 설명합니다.
응답 콘텐츠를 캡처하기 위한 필터 생성
응답 콘텐츠를 캡처하려면, HttpServletResponse 객체를 래핑하고 getOutputStream() 및 getWriter() 메서드를 재정의하는 사용자 정의 필터를 생성해야 합니다. 이러한 메서드는 응답 데이터를 쓰기 위한 스트림을 제공하는 역할을 담당합니다. 이를 재정의함으로써 데이터를 가로채서 버퍼에 복사하는 사용자 정의 스트림을 생성할 수 있습니다.
다음은 이 작업을 수행하는 필터의 예입니다.
@WebFilter("/*") public class ResponseLogger implements Filter { @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) { 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())); } } }
응답 래퍼 사용자 정의
HttpServletResponseCopier 클래스는 원본을 래핑합니다. HttpServletResponse를 사용하고 데이터를 가로채는 사용자 정의 ServletOutputStream을 생성합니다. 재정의된 getOutputStream() 및 getWriter() 메서드는 ServletOutputStreamCopier 인스턴스를 생성하고 반환합니다.
public class HttpServletResponseCopier extends HttpServletResponseWrapper { private ServletOutputStreamCopier copier; @Override public ServletOutputStream getOutputStream() { if (copier == null) { copier = new ServletOutputStreamCopier(getResponse().getOutputStream()); } return copier; } @Override public PrintWriter getWriter() { if (copier == null) { copier = new ServletOutputStreamCopier(getResponse().getOutputStream()); } return new PrintWriter(new OutputStreamWriter(copier, getResponse().getCharacterEncoding()), true); } }
응답 데이터 가로채기 및 복사
ServletOutputStreamCopier 클래스는 write( int b) 응답에 기록된 데이터를 가로채는 방법입니다. 데이터를 원본 스트림에 쓰는 동시에 나중에 검색하기 위해 ByteArrayOutputStream에 복사합니다.
public class ServletOutputStreamCopier extends ServletOutputStream { private ByteArrayOutputStream copy; @Override public void write(int b) { outputStream.write(b); copy.write(b); } public byte[] getCopy() { return copy.toByteArray(); } }
캡처된 응답 검색
요청-응답 주기 후 완료되면 필터는 ServletOutputStreamCopier의 getCopy()에서 캡처된 응답 콘텐츠를 검색합니다. 방법. 이 데이터는 로깅이나 기타 원하는 목적으로 사용될 수 있습니다.
위 내용은 Java에서 HTTP 서블릿 응답 콘텐츠를 캡처하고 기록하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!