在微服务中,我们所有的服务都是访问自己的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(“你已被拦截”); 返回消息主体
