当前位置: 首页>>代码示例>>Java>>正文


Java ContentCachingResponseWrapper类代码示例

本文整理汇总了Java中org.springframework.web.util.ContentCachingResponseWrapper的典型用法代码示例。如果您正苦于以下问题:Java ContentCachingResponseWrapper类的具体用法?Java ContentCachingResponseWrapper怎么用?Java ContentCachingResponseWrapper使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


ContentCachingResponseWrapper类属于org.springframework.web.util包,在下文中一共展示了ContentCachingResponseWrapper类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: doFilterInternal

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Override
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
        throws ServletException, IOException {
    ContentCachingRequestWrapper requestWrapper = new ContentCachingRequestWrapper(request);
    ContentCachingResponseWrapper responseWrapper = new ContentCachingResponseWrapper(response);

    try {
        filterChain.doFilter(requestWrapper, responseWrapper);
    } finally {
        String requestBody = new String(requestWrapper.getContentAsByteArray());
        log.info("Request body: {}", requestBody);

        String responseBody = new String(responseWrapper.getContentAsByteArray());
        log.info("Response body: {}", responseBody);

        // Do not forget this line after reading response content or actual response will be empty!
        responseWrapper.copyBodyToResponse();
    }
}
 
开发者ID:amvnetworks,项目名称:amv-access-api-poc,代码行数:20,代码来源:PayloadLoggingFilter.java

示例2: extractResponseResult

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
/**
 * 提取请求结果
 * @param request
 * @param loggingContext
 * @return
 */
protected Object extractResponseResult(HttpServletResponse response, LoggingContext loggingContext) throws Exception {
	MediaType contentType = loggingContext.getHttpAccessLog().getResponseContentType();
	if(contentType != null){
		if(isContentCachingResponse(response)){
			String charset = response.getCharacterEncoding();
			if(StringUtils.isEmpty(charset)){
				charset = StringUtils.defaultIfEmpty(contentType.getCharset().name(), GlobalConstants.SYSTEM_DEFAULT_CHARSET);
			}
			ContentCachingResponseWrapper responseToUse = (ContentCachingResponseWrapper) response;
			byte[] bytes = responseToUse.getContentAsByteArray();
			if(bytes != null){
				return IOUtils.toString(bytes, charset);
			}
		}
	}
	return null;
}
 
开发者ID:penggle,项目名称:xproject,代码行数:24,代码来源:AbstractHttpAccessLoggingInterceptor.java

示例3: updateResponse

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
private void updateResponse(String requestURI, ContentCachingResponseWrapper responseWrapper) throws IOException {
	try {
		HttpServletResponse rawResponse = (HttpServletResponse) responseWrapper.getResponse();
		byte[] body = responseWrapper.getContentAsByteArray();
		ServletOutputStream outputStream = rawResponse.getOutputStream();
		if (rawResponse.isCommitted()) {
			if (body.length > 0) {
				StreamUtils.copy(body, outputStream);
			}
		} else {
			if (body.length > 0) {
				rawResponse.setContentLength(body.length);
				StreamUtils.copy(body, rawResponse.getOutputStream());
			}
		}
		finishResponse(outputStream, body);
	} catch (Exception ex) {
		logger.error("请求地址为" + requestURI + "的连接返回报文失败,原因是{}", ex.getMessage());
	}
}
 
开发者ID:wengwh,项目名称:plumdo-stock,代码行数:21,代码来源:RequestLogFilter.java

示例4: doFilterInternal

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Override
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {
	long begintime = DateUtils.currentTimeMillis();
	JsonContentCachingRequestWrapper requestWrapper = new JsonContentCachingRequestWrapper(request);
	ContentCachingResponseWrapper responseWrapper = new ContentCachingResponseWrapper(response);
	filterChain.doFilter(requestWrapper, responseWrapper);
	long timecost = DateUtils.getTimeMillisConsume(begintime);
	String requestURI = request.getRequestURI();
	String ip = request.getRemoteAddr();
	String requestParam = convertString(requestWrapper.getContentAsByteArray());
	updateResponse(requestURI, responseWrapper);
	if (isNotJsonContentType(responseWrapper.getContentType())) {
		logger.debug("ip:{} 调用接口,请求地址为:{}, 请求参数为:{},[{}]ms", ip, requestURI, requestParam, timecost);
	} else {
		String result = convertString(responseWrapper.getContentAsByteArray());
		logger.debug("ip:{} 调用接口,请求地址为:{}, 请求参数为:{},返回值是{},[{}]ms", ip, requestURI, requestParam, result, timecost);
	}
}
 
开发者ID:wengwh,项目名称:plumdo-stock,代码行数:19,代码来源:RequestLogFilter.java

示例5: getResponseContent

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
private static String getResponseContent(HttpServletResponse response) {
    if (response instanceof ContentCachingResponseWrapper) {
        return new String(((ContentCachingResponseWrapper) response).getContentAsByteArray());
    }
    if (response instanceof HttpServletResponseWrapper
        && ((HttpServletResponseWrapper) response).getResponse() instanceof ContentCachingResponseWrapper) {
        return new String(((ContentCachingResponseWrapper) ((HttpServletResponseWrapper) response)
            .getResponse()).getContentAsByteArray());
    }
    log.warn("Empty response content because of unsupported response class {}", response.getClass());
    return "";
}
 
开发者ID:xm-online,项目名称:xm-commons,代码行数:13,代码来源:TimelineEventProducer.java

示例6: wrapResponseIfNeeded

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
/**
 * wrap the {@link HttpServletResponse} in a {@link ContentCachingResponseWrapper} if it is not already one.
 * 
 * @param httpServletResponse
 * @return
 */
protected ContentCachingResponseWrapper wrapResponseIfNeeded(HttpServletResponse httpServletResponse) {
	if (!(httpServletResponse instanceof ContentCachingResponseWrapper)) {
		return new ContentCachingResponseWrapper(httpServletResponse);
	} else {
		return (ContentCachingResponseWrapper) httpServletResponse;
	}
}
 
开发者ID:alecalanis,项目名称:session-to-cookie,代码行数:14,代码来源:SessionToCookieFilter.java

示例7: isContentCachingResponse

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
protected boolean isContentCachingResponse(ServletResponse response) {
	if(response instanceof ContentCachingResponseWrapper){
		return true;
	}else if(response instanceof HttpServletResponseWrapper) {
		HttpServletResponseWrapper responseToUse = (HttpServletResponseWrapper) response;
		return isContentCachingResponse(responseToUse.getResponse());
	}
	return false;
}
 
开发者ID:penggle,项目名称:xproject,代码行数:10,代码来源:AbstractHttpAccessLoggingInterceptor.java

示例8: getContentCachingResponseWrapper

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
/**
 * 获取ContentCachingResponseWrapper
 * (考虑到Wrapper是可以重复的,故需要递归获取)
 * @param response
 * @return
 */
protected ContentCachingResponseWrapper getContentCachingResponseWrapper(ServletResponse response) {
	if(response instanceof ContentCachingResponseWrapper){
		return (ContentCachingResponseWrapper) response;
	}else if(response instanceof HttpServletResponseWrapper) {
		HttpServletResponseWrapper responseToUse = (HttpServletResponseWrapper) response;
		return getContentCachingResponseWrapper(responseToUse.getResponse());
	}
	return null;
}
 
开发者ID:penggle,项目名称:xproject,代码行数:16,代码来源:HttpAccessLoggingServletStreamFilter.java

示例9: doFilterInternal

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Override
protected void doFilterInternal(HttpServletRequest request,
                                HttpServletResponse response,
                                FilterChain filterChain) throws ServletException, IOException {
    ContentCachingRequestWrapper requestWrapper = new ContentCachingRequestWrapper(request);
    ContentCachingResponseWrapper responseWrapper = new ContentCachingResponseWrapper(response);
    try {
        filterChain.doFilter(requestWrapper, responseWrapper);
    } finally {
        responseWrapper.copyBodyToResponse();
    }
}
 
开发者ID:xm-online,项目名称:xm-ms-dashboard,代码行数:13,代码来源:ContentCachingWrappingFilter.java

示例10: doFilterInternal_NoCacheRequestAndResponse_CallWithCacheRequestAndResponse

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Test
public void doFilterInternal_NoCacheRequestAndResponse_CallWithCacheRequestAndResponse() throws Exception {
	HttpServletRequest request = new MockHttpServletRequest();
	HttpServletResponse response = new MockHttpServletResponse();
	FilterChain filterChain = spy(new MockFilterChain());

	FILTER.doFilterInternal(request, response, filterChain);

	Mockito.verify(filterChain).doFilter(isA(ContentCachingRequestWrapper.class), isA
			(ContentCachingResponseWrapper.class));
}
 
开发者ID:cmateosl,项目名称:role-api,代码行数:12,代码来源:BaseLoggingFilterTest.java

示例11: doFilterInternal_CacheRequestAndNoCacheResponse_CallWithCacheRequestAndResponse

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Test
public void doFilterInternal_CacheRequestAndNoCacheResponse_CallWithCacheRequestAndResponse() throws Exception {
	HttpServletRequest cacheRequest = new ContentCachingRequestWrapper(new MockHttpServletRequest());
	HttpServletResponse response = new MockHttpServletResponse();
	FilterChain filterChain = spy(new MockFilterChain());

	ArgumentCaptor<HttpServletRequest> requestCaptor = ArgumentCaptor.forClass(HttpServletRequest.class);

	FILTER.doFilterInternal(cacheRequest, response, filterChain);

	Mockito.verify(filterChain).doFilter(requestCaptor.capture(), isA(ContentCachingResponseWrapper.class));
	assertThat(requestCaptor.getValue(), is(cacheRequest));
}
 
开发者ID:cmateosl,项目名称:role-api,代码行数:14,代码来源:BaseLoggingFilterTest.java

示例12: doFilterInternal_NoCacheRequestAndCacheResponse_CallWithCacheRequestAndResponse

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Test
public void doFilterInternal_NoCacheRequestAndCacheResponse_CallWithCacheRequestAndResponse() throws Exception {
	HttpServletRequest request = new MockHttpServletRequest();
	HttpServletResponse cacheResponse = new ContentCachingResponseWrapper(new MockHttpServletResponse());
	FilterChain filterChain = spy(new MockFilterChain());

	ArgumentCaptor<HttpServletResponse> responseCaptor = ArgumentCaptor.forClass(HttpServletResponse.class);

	FILTER.doFilterInternal(request, cacheResponse, filterChain);

	Mockito.verify(filterChain).doFilter(isA(ContentCachingRequestWrapper.class), responseCaptor.capture());
	assertThat(responseCaptor.getValue(), is(cacheResponse));
}
 
开发者ID:cmateosl,项目名称:role-api,代码行数:14,代码来源:BaseLoggingFilterTest.java

示例13: buildResponseLog_WithNoBody_ReturnStringResponseWithUriAndEmptyBody

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Test
public void buildResponseLog_WithNoBody_ReturnStringResponseWithUriAndEmptyBody() {
	MockHttpServletResponse response = new MockHttpServletResponse();

	String log = FILTER.buildResponseLog(new ContentCachingResponseWrapper(response));

	assertThat(log, is("Server responded with a response\n > 200\n[empty]"));
}
 
开发者ID:cmateosl,项目名称:role-api,代码行数:9,代码来源:BaseLoggingFilterTest.java

示例14: buildResponseLog_WithCorrectBody_ReturnStringResponseWithUriAndBody

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Test
public void buildResponseLog_WithCorrectBody_ReturnStringResponseWithUriAndBody() throws IOException {
	MockHttpServletResponse response = new MockHttpServletResponse();

	ContentCachingResponseWrapper responseWrapper = new ContentCachingResponseWrapper(response);
	responseWrapper.getWriter().print("test");

	String log = FILTER.buildResponseLog(responseWrapper);

	assertThat(log, is("Server responded with a response\n > 200\ntest"));
}
 
开发者ID:cmateosl,项目名称:role-api,代码行数:12,代码来源:BaseLoggingFilterTest.java

示例15: buildResponseLog_WithUnreadableBody_ReturnStringResponseWithUriAndUnknownBody

import org.springframework.web.util.ContentCachingResponseWrapper; //导入依赖的package包/类
@Test
public void buildResponseLog_WithUnreadableBody_ReturnStringResponseWithUriAndUnknownBody() throws IOException {
	MockHttpServletResponse response = new MockHttpServletResponse();

	ContentCachingResponseWrapper responseWrapper = spy(new ContentCachingResponseWrapper(response));
	responseWrapper.getWriter().print("test");
	//noinspection InjectedReferences
	responseWrapper.setCharacterEncoding("notExistThisEncoding");

	String log = FILTER.buildResponseLog(responseWrapper);

	assertThat(log, is("Server responded with a response\n > 200\n[unknown]"));
}
 
开发者ID:cmateosl,项目名称:role-api,代码行数:14,代码来源:BaseLoggingFilterTest.java


注:本文中的org.springframework.web.util.ContentCachingResponseWrapper类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。