Spring cloud 게 이 트 웨 이 는 반환 형식 을 모두 json 으로 설정 하고 파일 형식 을 처리 하지 않 습 니 다.
package com.**.saas.gateway.filter;
/**
* ,
*
* @author: ***
* @date: 2019/6/19 15:18
* @version: 1.0
*/
@Component
public class ResponseFilter extends ZuulFilter {
@Override
public String filterType() {
return FilterConstants.POST_TYPE;
}
@Override
public int filterOrder() {
return FilterConstants.SEND_RESPONSE_FILTER_ORDER;
}
@Override
public boolean shouldFilter() {
RequestContext context = getCurrentContext();
return !context.getRequest().getRequestURI().toString().contains("getDownloadExcel");
}
@Override
public Object run() throws ZuulException {
RequestContext context = getCurrentContext();//
context.addZuulResponseHeader("Content-Type", "application/json;charset=UTF-8");
InputStream inputStream = context.getResponseDataStream();
String responseBody;
try {
responseBody = StreamUtils.copyToString(inputStream, Charset.forName("UTF-8"));
} catch (IOException e) {
throw ExceptionUtil.buildZuulException(ResultEnum.SYSTEM_ERROR);
}
if (context.getResponseStatusCode() != 200) {// zuul
ZuulErrorBean zuulErrorBean = JsonUtil.json2Obj(responseBody, ZuulErrorBean.class);
if (zuulErrorBean != null) {
throw ExceptionUtil.buildZuulException(ResultDTO.fail(zuulErrorBean.getStatus(), zuulErrorBean.getError()));
}
return null;
}
context.setResponseBody(responseBody);
return null;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
thymeleaf로 HTML 페이지를 동적으로 만듭니다 (spring + gradle)지난번에는 에서 화면에 HTML을 표시했습니다. 이번에는 화면을 동적으로 움직여보고 싶기 때문에 입력한 문자를 화면에 표시시키고 싶습니다. 초보자의 비망록이므로 이상한 점 등 있으면 지적 받을 수 있으면 기쁩니다! ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.