zuul (1) pre 와 post 필터
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
zuul 설정 추가
zuul:
routes:
#
myProduct:
path: /myProduct/**
serviceId: product
# cookie
sensititiveHeaders:
#
# product: /myProduct/**
#
ignored-patterns:
- /**/product/listForOrder
management:
security:
enabled: false
main 방법 에 주 해 를 달다
@EnableZuulProxy//
새 클래스 ZuulConfig 는 통일 설정 센터 config 의 동적 새로 고침 에 사용 합 니 다.
@Component
public class ZuulConfig {
@ConfigurationProperties("zuul")
@RefreshScope//
public ZuulProperties zuulProperties(){
return new ZuulProperties();
}
}
첫 번 째 사용 상황 은 전치 (pre) 필 터 를 사용 하여 token 이 유효한 지 검증 합 니 다
/**
* token
* @author xwq
* @create 2020-04-23 15:13
**/
@Component
public class TockeFilter extends ZuulFilter {
@Override
public String filterType() {
return PRE_TYPE;
}
@Override
public int filterOrder() {
return PRE_DECORATION_FILTER_ORDER-1;
}
@Override
public boolean shouldFilter() {
return true;
}
/**
*
* @return
*/
@Override
public Object run() {
RequestContext requestContext = RequestContext.getCurrentContext();
HttpServletRequest request = requestContext.getRequest();
// url
String token = request.getParameter("token");
if(StringUtils.isEmpty(token)){
//
requestContext.setSendZuulResponse(false);
requestContext.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED);
}
return null;
}
}
두 번 째, 리 셋 (post) 을 사용 하여 되 돌아 오 는 결과 에 물건 을 추가 합 니 다.
/**
*
*
* @author xwq
* @create 2020-04-23 15:28
**/
@Component
public class AddResponseHeaderFilter extends ZuulFilter {
@Override
public String filterType() {
return POST_TYPE;
}
@Override
public int filterOrder() {
return SEND_RESPONSE_FILTER_ORDER - 1;
}
@Override
public boolean shouldFilter() {
return true;
}
/**
*
*
* @return
*/
@Override
public Object run() {
RequestContext requestContext = RequestContext.getCurrentContext();
HttpServletResponse response = requestContext.getResponse();
response.setHeader("X-Foo", UUID.randomUUID().toString());
System.out.println(".....");
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에 따라 라이센스가 부여됩니다.