Spring Cloud Gateway提供的簡易網(wǎng)關(guān)實現(xiàn)方式,你使用過嗎?
環(huán)境:SpringBoot2.5.13
Spring Cloud Gateway提供了一個名為ProxyExchange的實用程序?qū)ο?。你可以在常?guī)Spring web處理程序中使用它作為方法參數(shù)。它通過鏡像HTTP動詞的方法支持基本的下游HTTP交換。在MVC中,它還支持通過forward()方法轉(zhuǎn)發(fā)到本地處理程序。要使用ProxyExchange,需要在classpath中包含正確的模塊(spring-cloud-gateway-mvc(3.1.5)或spring-cloud-gateway-webflux)。
下面的MVC示例將請求代理到/test下游到遠(yuǎn)程服務(wù)器:
@RestController
@SpringBootApplication
public class GatewaySampleApplication {
@Value("${remote.home}")
private URI home;
@GetMapping("/test")
public ResponseEntity<?> proxy(ProxyExchange<byte[]> proxy) throws Exception {
return proxy.uri(home.toString() + "/image/png").get();
}
}下面的例子對Webflux做了相同的事情:
@RestController
@SpringBootApplication
public class GatewaySampleApplication {
@Value("${remote.home}")
private URI home;
@GetMapping("/test")
public Mono<ResponseEntity<?>> proxy(ProxyExchange<byte[]> proxy) throws Exception {
return proxy.uri(home.toString() + "/image/png").get();
}
}ProxyExchange上的便利方法使處理程序方法能夠發(fā)現(xiàn)并增強(qiáng)傳入請求的URI路徑。例如,你可能想提取路徑末尾的元素并將其傳遞到下游:
@GetMapping("/proxy/path/**")
public ResponseEntity<?> proxyPath(ProxyExchange<byte[]> proxy) throws Exception {
// 如這里請求的/proxy/path/666,那么這里path = 666
String path = proxy.path("/proxy/path/");
return proxy.uri(home.toString() + "/foos/" + path).get();
}目標(biāo)服務(wù)接口
@RestController
@RequestMapping("/business")
public class BusinessController {
@PostMapping("/index")
public Object index(@RequestBody Map<String ,Object> body) {
System.out.println("業(yè)務(wù)接口接收到的內(nèi)容:" + body) ;
Map<String, Object> result = new HashMap<>() ;
result.put("code", 0) ;
result.put("data", "業(yè)務(wù)處理成功 - " + LocalDateTime.now().getNano()) ;
result.put("message", "success") ;
return result ;
}
}網(wǎng)關(guān)服務(wù)接口
@RestController
@RequestMapping("/proxy/api")
public class GatewayController {
@GetMapping("")
public Object order(@RequestHeader("token") String token,
Integer id, ProxyExchange<Map<String, Object>> exchange) {
System.out.println("token = " + token + ", id = " + id) ;
Map<String, Object> body = new HashMap<>() ;
body.put("id", id) ;
body.put("token", token) ;
return exchange.uri("http://localhost:9000/business/index").body(body).post() ;
}
}調(diào)用結(jié)果
圖片
Postman請求
控制臺輸出
你還可以使用ProxyExchange的header()方法向下游響應(yīng)添加header。
exchange.uri("http://localhost:9000/business/index").header("key", "123123").body(body).post() ;你還可以通過在get()方法(以及其他方法)中添加一個mapper來操作響應(yīng)頭(以及響應(yīng)中的其他任何內(nèi)容)。mapper是一個Function,接收傳入的ResponseEntity并將其轉(zhuǎn)換為傳出的ResponseEntity,如下:
exchange.uri("http://localhost:9000/business/index").header("key", "123123").body(body).post(result -> {
System.out.println("Resposne Header: " + result.getHeaders()) ;
return ResponseEntity.ok("success") ;
}) ;對于“敏感”標(biāo)頭(默認(rèn)情況下為cookie和authorization)和“代理”(x-forward-*)頭,提供了非常好的支持,這些頭不會向下游傳遞。如:
當(dāng)我們的請求中有Authorization 請求Header信息時,默認(rèn)將不會向下游傳遞,這是默認(rèn)行為還有cookie。我們可以通過修改配置文件覆蓋。
spring:
cloud:
gateway:
proxy:
sensitive:
- ''完畢?。。?/p>


































