Spring boot2.0.x+SpringCloud(Finchley版本)分佈式架構--路由網關(zuul)(四)

前言聲明:
如果您有更好的技術與作者分享,或者商業合作;請訪問作者個人網站 http://www.esqabc.com/view/message.html 留言給作者。
如果該案例觸犯您的專利,請在這裏:http://www.esqabc.com/view/message.html 留言給作者說明原由,作者一經查實,馬上刪除。

四,路由網關的轉發路由與過濾(zuul)

開始前準備工作:
1,創建一個項目(esq-routing)
架構如下:
在這裏插入圖片描述
1,pom配置文件添加:

<?xml version="1.0"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <!-- 父項目 -->
  <parent>
    <groupId>com.esq.master</groupId>
    <artifactId>esq-master</artifactId>
    <version>1.0.0</version>
  </parent>
  <!-- 本項目信息 -->
  <groupId>com.esq.routing</groupId>
  <artifactId>esq-routing</artifactId>
  <name>esq-routing</name>
  <url>http://maven.apache.org</url>
  <description>分佈式路由器</description>
   <!-- 配置編碼格式  begin -->
  <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  </properties>
  <!-- 配置編碼格式  end -->
  
  
  <!-- JAR包配置  begin-->
  <dependencies>
  		 <!-- Cloud 服務需要的jar包-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <!-- Springboot web服務器的jar-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- 分佈式路由器 zuul的jar-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        </dependency>
  </dependencies>
  <!-- JAR包配置  end-->
  
  
  
  <!-- 插件配置  begin -->
   <build>
	<plugins>
	

	</plugins>	
   </build>
  <!-- 插件配置  end -->
</project>

2,application.properties改造:


#配置啓動端口號
server.port=9003
#配置項目訪問路徑
#server.context-path=/eureka
#配置服務名稱
spring.application.name=esq-routing
#配置服務註冊中心地址
eureka.client.serviceUrl.defaultZone=http://localhost:9000/eureka/

#以/rib/ 開頭的請求都轉發給esq-consumerrib服務(既服務消費者:esq-consumerRib)
zuul.routes.rib.path=/rib/**
zuul.routes.rib.serviceId=esq-consumerrib
#以/fei/開頭的請求都轉發給esq-consumerfei服務(既服務消費者:esq-consumerFei)
zuul.routes.fei.path=/fei/**
zuul.routes.fei.serviceId=esq-consumerfei

3,啓動文件(RoutingApplication):

package com.esq.routing;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.boot.CommandLineRunner;
import java.util.Arrays;
/**
 * 分佈式路由器啓動類
 * @author esq
 * @Create 2019-09-09 09:09:09
 * @Website www.esqabc.com
 * @WeChat 
 */
@SpringBootApplication
@EnableZuulProxy
@EnableEurekaClient
@EnableDiscoveryClient
public class RoutingApplication{

	public static void main(String[] args) {
		System.out.println("。。。。。。分佈式路由器程序開始啓動。。。。。。");
		long startTime = System.currentTimeMillis();    //獲取開始時間
		SpringApplication.run(RoutingApplication.class, args);
		long endTime = System.currentTimeMillis();    //獲取結束時間
		System.out.println("分佈式路由器程序啓動用時:" + (endTime - startTime) + "毫秒");//輸出程序運行時間
		System.out.println("分佈式路由器程序啓動一共用時:" + (endTime - startTime)/60 + "秒。。。。。。");
		System.out.println("。。。。。。分佈式路由器程序啓動成功。。。。。。");
	}
	@Bean
	public CommandLineRunner commandLineRunner(ApplicationContext ctx) {
		
	   return args -> {
	       String[] beanNames = ctx.getBeanDefinitionNames();
	       Arrays.sort(beanNames);
	       Arrays.stream(beanNames).forEach(System.out::println);
	   };
	}	
	
}

4,啓動項目:
1)在瀏覽器輸入:http://localhost:9003/rib/esquser?name=123

交替顯示:歡迎123訪問,來自服務端口:9011的服務。,歡迎123訪問,來自服務端口:9022的服務。

2)在瀏覽器輸入:http://localhost:9003/fei/esquser?name=123

交替顯示:歡迎123訪問,來自服務端口:9011的服務。,歡迎123訪問,來自服務端口:9022的服務。

5,添加過濾器(攔截器)RoutingFilter:

package com.esq.routing.system;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

/**
 * zuul路由服務過濾(攔截器)
 * @author esq
 * @Create 2019-09-09 09:09:09
 * @Website www.esqabc.com
 * @WeChat 
 */
@Component
public class RoutingFilter extends ZuulFilter{
	
	private static Logger log = LoggerFactory.getLogger(RoutingFilter.class);
	
	/**
	 * 是否要過濾
	 * true:過濾
	 * false:不過濾
	 */
	public boolean shouldFilter() {
		//這裏可以寫邏輯判斷
		return true;
	}
	/**
	 * 過濾器的具體邏輯
	 */
	public Object run(){
		RequestContext ctx = RequestContext.getCurrentContext();
        HttpServletRequest request = ctx.getRequest();
        //獲取令牌token
        Object accessToken = request.getParameter("token");
        if(accessToken == null) {
            log.warn("令牌不能爲空呀,請登錄後再試!");
            ctx.setSendZuulResponse(false);
            ctx.setResponseStatusCode(401);
            try {
                ctx.getResponse().getWriter().write("令牌不能爲空呀,請登錄後再試!");
            }catch (Exception e){}
            
            return null;
        }
        log.info("通過");
        return null;
	}
	
	/**
	 * 返回一個字符串代表過濾器的類型
	 * pre:路由之前
	 * routing:路由之時
	 * post: 路由之後
	 * error:發送錯誤調用
	 */
	public String filterType() {
		return "pre";
	}
	/**
	 * 過濾的順序
	 */
	public int filterOrder() {
		return 0;
	}

}

注意:項目啓動順序爲:先啓動註冊中心(esq-registry) ,然後啓動(服務生產者1,2)(esq-provider-a,esq-provider-b) 啓動服務消費者1,2(esq-consumerFei,esq-consumerRib),最後啓動路由(esq-routing)

6,啓動項目:
1)在瀏覽器輸入:http://localhost:9003/rib/esquser?name=123&token=22

交替顯示:歡迎123訪問,來自服務端口:9011的服務。,歡迎123訪問,來自服務端口:9022的服務。

2)在瀏覽器輸入:http://localhost:9003/rib/esquser?name=123

交替顯示:令牌不能爲空呀,請登錄後再試!(注意如果是返回中文,請設置中文編碼,不然會變成:???)

===============================

更多請訪問:https://blog.csdn.net/esqabc/article/details/87804603

=================================

發佈了33 篇原創文章 · 獲贊 7 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章