zuul网关有路由和过滤器等作用
简单使用路由部分功能:
路由功能:使用户不直接访问服务,而是访问网关,网关在去eureka上拉去服务然后比对用户请求是要请求哪个服务,然后将请求发送给这个服务。
1、在父类工程中创建gateway子工程,用来充当网关部分
2、引入相关依赖,引入eureka方便我们在路由中直接指定服务ID
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
3、在启动类上使用@EnableDiscoveryClient@EnableZuulProxy注解。
4、在配置文件中配置路由部分
server:
port: 8888
spring:
application:
name: gateway
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:9999/eureka
zuul:
routes:
xx:
path: /search/**
serviceId: search-service
在routes中可以配置唯一ID(名称随意),然后再配置path和serviceID等信息来进行路由。用户可以访问http://127.0.0.1:8888/search/xxx来访问search-service。
路由简化配置:
zuul:
routes:
search-service: /search/**
如果有服务不想对外暴露可以使用ignore
zuul:
routes:
search-service: /search/**
ignored-services:
- test_service
还有一些前缀等配置信息。
zuul:
routes:
search-service: /search1/**
ignored-services:
- test_service
strip-prefix: true
prefix: /xxx
简单使用过滤器部分功能
1、过滤器的种类有四种:在FilterConstants类中可以看到
/**
* {@link ZuulFilter#filterType()} error type.
*/
public static final String ERROR_TYPE = "error";
/**
* {@link ZuulFilter#filterType()} post type.
*/
public static final String POST_TYPE = "post";
/**
* {@link ZuulFilter#filterType()} pre type.
*/
public static final String PRE_TYPE = "pre";
/**
* {@link ZuulFilter#filterType()} route type.
*/
public static final String ROUTE_TYPE = "route";
2、过滤器顺序一般是:先前置再到路由再到post再进行继续请求,当中间有异常的时候进入error然后再重新进入post,再继续请求。
前置过滤器一般做登陆校验、权限校验、限流等
简单模拟一个登陆校验,判断请求头中是否有token,如果有则默认校验通过。
@Component
public class LoginFilter extends ZuulFilter {
@Override
public String filterType() {
return FilterConstants.PRE_TYPE;
}
@Override
public int filterOrder() {
return FilterConstants.FORM_BODY_WRAPPER_FILTER_ORDER - 1;
}
@Override
public boolean shouldFilter() {
return true;
}
@Override
public Object run() throws ZuulException {
//获取上下文对象
RequestContext requestContext = RequestContext.getCurrentContext();
HttpServletRequest request = requestContext.getRequest();
String token = request.getParameter("token");
if (StringUtils.isBlank(token)) {
requestContext.setSendZuulResponse(false);
requestContext.setResponseStatusCode(HttpStatus.FORBIDDEN.value());
}
return null;
}
}
filterType指定过滤器类型。
filterOrder指定过滤器加载顺序。这里选择里表单信息封装之前。
shouldFilter为true该过滤器生效,false不生效。
run为我们的业务逻辑,通过会调用的是上下文对象的zuulresponse,如果不通过则返回false。
其实还可以使用zuul与shiro一起进行一个权限校验,这样就可以不用在每个服务中都去进行shiro的校验了。