SpringCloud Zuul自定義filter代碼實(shí)例
實(shí)現(xiàn)過濾器很簡單,只需要繼承ZuulFilter,并實(shí)現(xiàn)ZuulFilter中的抽象方法。
- filterType():定義過濾器的類型,它有4種類型,分別是pre、post、routing和error
- filterOrder():過濾順序,它是一個(gè)Int類型的值,值越小,越早執(zhí)行該過濾器
- shouldFilter():表示該過濾器是否過濾邏輯,如果為true,則執(zhí)行run方法,如果為false,則不執(zhí)行run方法
- Object run():寫具體的過濾邏輯
注意重要說明,有些版本在轉(zhuǎn)發(fā)post時(shí),文件上傳無法轉(zhuǎn)法。只要升級下版本就可以了。
本示中使用的是 springcloud Edgware.RELEASE 對應(yīng)springboot1.5.9
| Spring Boot | Spring Cloud |
| 1.2.x | Angel版本 |
| 1.3.x | Brixton版本 |
| 1.4.xstripes | Camden版本 |
| 1.5.x | Dalston版本、Edgware版本 |
| 2.0.x | Finchley版本 |
| 2.1.x | Greenwich.SR2 |
示例
1.pom中引用
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.company</groupId>
<artifactId>zuuldemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>zuuldemo</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<parent>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-parent</artifactId>
<version>Edgware.RELEASE</version>
<relativePath></relativePath>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.58</version>
</dependency>
</dependencies>
</project>
2.springcloud項(xiàng)目
2.1 src/main/resources/application.yml
server:
port: 80
spring:
application:
name: api-geteway
http:
multipart:
enabled: true # 使用http multipart上傳處理
file-size-threshold: 1MB # 當(dāng)上傳文件達(dá)到1MB的時(shí)候進(jìn)行磁盤寫入
max-request-size: 10MB # 設(shè)置最大的請求文件的大小
max-file-size: 10MB # 設(shè)置單個(gè)文件的最大長度
zuul:
routes:
weixin:
path: /mypath/**
url: https://www.baidu.com
2.2 App.java
package com.company.zuuldemo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
import org.springframework.context.annotation.Bean;
import com.company.zuuldemo.filter.MyFilter;
/**
* Hello world!
*
*/
@EnableZuulProxy
@SpringBootApplication
public class ZuulApp {
//使用filter
@Bean
public MyFilter myFilter() {
return new MyFilter();
}
// @Bean
// public FirstFilter firstFilter() {
// return new FirstFilter();
// }
//
// @Bean
// public SecondFilter secondFilter() {
// return new SecondFilter();
// }
public static void main(String[] args) {
// System.out.println( "Hello World!" );
SpringApplication.run(ZuulApp.class);
}
}
2.3 MyFilter.java
package com.company.zuuldemo.filter;
import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
public class MyFilter extends ZuulFilter {
final static Logger logger = LoggerFactory.getLogger(FirstFilter.class);
// 這里可以依據(jù)url規(guī)則判斷是否需要進(jìn)行過濾 true需要過濾進(jìn)入run方法 ,false直接忽略
public boolean shouldFilter() {
RequestContext ctx = RequestContext.getCurrentContext();
logger.info(ctx.getRequest().getRequestURI() + " get request path info");
String url = ctx.getRequest().getRequestURI().toLowerCase();
// 這里判斷url邏輯
if (url.startsWith("/login")) {
return false;
}
return true;
}
public Object run() {
RequestContext ctx = RequestContext.getCurrentContext();
// 通過其它業(yè)務(wù)生成token
String access_token = "user_name_token";
// 使用1 :向request的header中增加參數(shù)access_token
ctx.addZuulRequestHeader("access_token", access_token);
// 使用2:向request的url里增加參數(shù),示例增加 access_token
Map<String, List<String>> requestQueryParams = ctx.getRequestQueryParams();
if (requestQueryParams == null) {
requestQueryParams = new HashMap<>();
}
requestQueryParams.put("access_token", Arrays.asList(access_token));
ctx.setRequestQueryParams(requestQueryParams);
//使用3 ::判斷是否登錄,如果未登錄直接返回404
if (access_token == null || access_token.trim().length() == 0) {
//過濾該請求,不對其進(jìn)行路由(直接輸入返回)
ctx.setSendZuulResponse(false);
//返回錯(cuò)誤碼
ctx.setResponseStatusCode(401);
// 返回錯(cuò)誤內(nèi)容
ctx.setResponseBody("{\"result\":\"access_token is not correct!\"}");
//讓下一個(gè)Filter看到上一個(gè)Filter的狀態(tài)用于過濾器間的協(xié)調(diào)
ctx.set("my_filter_is_success", false);
return null;
}
// 對該請求進(jìn)行路由(默認(rèn)就是true)
//ctx.setSendZuulResponse(true);
//ctx.setResponseStatusCode(200);
//讓下一個(gè)Filter看到上一個(gè)Filter的狀態(tài)用于過濾器間的協(xié)調(diào)
ctx.set("my_filter_is_success", false);
return null; //直接返回null即可
}
@Override
public String filterType() {
// 前置過濾器
//pre:可以在請求被路由之前調(diào)用
//route:在路由請求時(shí)候被調(diào)用
//post:在route和error過濾器之后被調(diào)用
//error:處理請求時(shí)發(fā)生錯(cuò)誤時(shí)被調(diào)用
return "pre";
}
@Override
public int filterOrder() {
//優(yōu)先級為0,數(shù)字越大,優(yōu)先級越低
return 0;
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 解決springcloud Zuul丟失Cookie的問題
- SpringCloud Zuul基本使用方法匯總
- SpringCloud Zuul服務(wù)功能與使用方法解析
- SpringCloud Zuul過濾器和谷歌Gauva實(shí)現(xiàn)限流
- SpringCloud Zuul網(wǎng)關(guān)功能實(shí)現(xiàn)解析
- SpringCLoud搭建Zuul網(wǎng)關(guān)集群過程解析
- SpringCloud Zuul過濾器實(shí)現(xiàn)登陸鑒權(quán)代碼實(shí)例
- SpringCloud網(wǎng)關(guān)組件zuul實(shí)例解析
- springcloud教程之zuul路由網(wǎng)關(guān)的實(shí)現(xiàn)
- SpringCloud Zuul實(shí)現(xiàn)動態(tài)路由
- SpringCloud Zuul的使用簡介
相關(guān)文章
2020年IntelliJ IDEA最新最詳細(xì)配置圖文教程詳解
這篇文章主要介紹了2020年IntelliJ IDEA最新最詳細(xì)配置圖文教程詳解,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
Spring Boot結(jié)合IDEA自帶Maven插件如何快速切換profile
IDEA是目前 Java 開發(fā)者中使用最多的開發(fā)工具,它有著簡約的設(shè)計(jì)風(fēng)格,強(qiáng)大的集成工具,便利的快捷鍵,這篇文章主要介紹了Spring Boot結(jié)合IDEA自帶Maven插件快速切換profile,需要的朋友可以參考下2023-03-03
MyBatis-Plus通過version機(jī)制實(shí)現(xiàn)樂觀鎖的思路
version機(jī)制的核心思想就是,假設(shè)發(fā)生并發(fā)沖突的幾率很低,只有當(dāng)更新數(shù)據(jù)的時(shí)候采取檢查是否有沖突,而判斷是否有沖突的依據(jù)就是version的值是否被改變了,這篇文章主要介紹了MyBatis-Plus通過version機(jī)制實(shí)現(xiàn)樂觀鎖的思路,需要的朋友可以參考下2021-09-09
解析Java實(shí)現(xiàn)隨機(jī)驗(yàn)證碼功能的方法詳解
本篇文章是對Java實(shí)現(xiàn)隨機(jī)驗(yàn)證碼功能的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
SPFA算法的實(shí)現(xiàn)原理及其應(yīng)用詳解
SPFA算法,全稱為Shortest?Path?Faster?Algorithm,是求解單源最短路徑問題的一種常用算法,本文就來聊聊它的實(shí)現(xiàn)原理與簡單應(yīng)用吧2023-05-05

