在微服务中,我们所有的服务都是访问自己的ip或者微服务名称这样大大提高了代码复杂程度,同时也将我们所有的微服务暴露给了用户,这样是不好滴,这个时候我们想要统一ip进行访问所有的微服务,那么zull网关就帮我们做到了这一点,zull网关大家可以了解为类似于nginx反向代理会比较好理解吧。下面直接来使用zull吧:
首先我们想要在pom中导入zull:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
第二部配置yml:
zuul:
host:
connect-timeout-millis: 60000
socket-timeout-millis: 60000
sensitive-headers: Access-Control-Allow-Origin
ignored-headers: Access-Control-Allow-Origin,H-APP-Id,Token,APPToken
routes:
auth: #认证服务
#响应的路径
path: /test/**
#敏感头信息
sensitiveHeaders:
#重定向到的服务(根据服务id名称从注册中心获取服务地址)
serviceId: service-test
#添加代理头
add-proxy-headers: true
可以看到routes中的配置我们的响应路径是test,那么我们会重定向到service-test,这里注意这个重定向服务一定是你的注册中心里面有的服务,这个时候你就访问试试了,访问路径一般是
ip:端口/test/对于ip:端口/service-test再到该项目路径下的方法就可以啦,
第三步添加注解到启动类:
@EnableZuulProxy
这样子一个网关就算是大功告成了,那么接下来我们就可以在该网关下配置过滤器,处理一下跨域请求的问题,大家根据自己需求配置:
HttpServletResponse response = (HttpServletResponse) res;
String originHeader = ((HttpServletRequest) req).getHeader("Origin");
System.out.println(originHeader);
response.setHeader("Access-Control-Allow-Origin", "*");
response.setHeader("Access-Control-Allow-Methods", "*");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "*");
response.setHeader("Access-Control-Allow-Credentials", "true");
chain.doFilter(req, res);
zull 4种过滤器:
pre:可以在请求被路由之前调用
route:在路由请求时候被调用
post:在route和error过滤器之后被调用
error:处理请求时发生错误时被调用
那么我们怎么使用这些过滤器,我们只需要创建一个类继承ZuulFilter:
filterType:使用那种过滤器:pre,rote,post,error
filterOrder:过滤器的执行顺序,字越大表示优先级越低,越后执行
shouldFilter:过滤器是否会被执行,
run:主要编写过滤逻辑,这边可以在过滤逻辑中配置自己的白名单,requestContext.setSendZuulResponse(false):跳出过滤器,不在执行
requestContext.setResponseStatusCode(500); 返回状态码
requestContext.setResponseBody(“你已被拦截”); 返回消息主体