1.Zuul网关?
是什么:网关相当于一个网络服务架构的入口,所有网络请求必须通过网关转发到具体的服务。
作用:统一管理微服务请求,登录验证,权限控制、负载均衡、路由转发、监控、安全控制黑名单和白名单等
区别:网关是对所有服务的请求进行分析过滤,过滤器是对单个服务而言。
2.创建Module项目springcloud-zuul
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.itlinli</groupId>
<artifactId>springcould-zuul</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>springcould-zuul</name>
<description>Demo project for Spring Boot</description>
<parent>
<groupId>com.itlinli</groupId>
<artifactId>springcould-2</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<dependencies>
<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>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
3.配置文件
eureka.client.serviceUrl.defaultZone=http://localhost:8800/eureka/
server.port=8400
spring.application.name=service-zuul
#表示注册中心的consumer-feign下面的所有访问请求路径都由/itlinli代替
#zuul.routes.consumer-feign=/itlinli/**
#表示注册中心的consumer-hystrix下面的所有访问请求路径都由/itlinli-hystrix代替
zuul.routes.consumer-hystrix=/itlinlihystrix/**
4.启动类
@SpringBootApplication
@EnableZuulProxy
public class SpringcouldZuulApplication {
public static void main(String[] args) {
SpringApplication.run(SpringcouldZuulApplication.class, args);
}
}
5.访问消费者中的方法就需要加/itlinli/路径访问
6.zuul过滤器
package com.itlinli.filter;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.servlet.http.HttpServletRequest;
@Component
public class TokenFilter extends ZuulFilter {
private static Logger log = LoggerFactory.getLogger(TokenFilter.class);
/**
返回一个字符串代表过滤器的类型,
pre:路由之前
routing:路由之时
post: 路由之后
error:发送错误调用
*/
@Override
public String filterType() {
return "pre";
}
/**
过滤的顺序
*/
@Override
public int filterOrder() {
return 0;
}
/**
这里可以写逻辑判断,是否要过滤,本文true,永远过滤。
*/
@Override
public boolean shouldFilter() {
return true;
}
/**
过滤器的具体逻辑。
*/
@Override
public Object run() throws ZuulException {
RequestContext ctx = RequestContext.getCurrentContext();
HttpServletRequest request = ctx.getRequest();
log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));
Object accessToken = request.getParameter("token");
if(accessToken == null) {
log.warn("token is empty");
ctx.setSendZuulResponse(false);
ctx.setResponseStatusCode(401);
try {
ctx.getResponse().getWriter().write("token is empty");
}catch (Exception e){}
return null;
}
log.info("ok");
return null;
}
}
7.请求的时候需要携带token
调用方法失败是因为我没有启动提供者。他调用了熔断器的方法