1. 環(huán)境信息
- java 1.8
- SpringBoot 2.4.4
- SpringGateway 3.0.5
2. 配置application.properties
證書生成方法,參考《使用keytool生成SSL證書》
... 省略
# 啟用https之后,這是https的端口丈咐。server-port來自System.setProperty("Server-port" , "12345")
server.port=${server-port}
# https
server.ssl.enabled=true
server.ssl.key-alias=gateway
server.ssl.key-store-password=Tpcloud@321
# 把證書放在應(yīng)用的配置目錄下她倘,不打包到Jar里面怔鳖。System.setProperty("app.dir.config" , "應(yīng)用配置目錄")
server.ssl.key-store=${app.dir.config}/gateway.pfx
server.ssl.key-store-type=PKCS12
#
spring.cloud.gateway.httpclient.ssl.useInsecureTrustManager=true
spring.cloud.gateway.httpclient.ssl.handshake-timeout-millis=10000
spring.cloud.gateway.httpclient.ssl.close-notify-flush-timeout-millis=3000
spring.cloud.gateway.httpclient.ssl.close-notify-read-timeout-millis= 0
... 省略
3. 支持上Http服務(wù)手报。
需要確保下面這個(gè)類能被Spring掃描到彤侍。
package com.xxxx.xxxx.ms.gateway.componet;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.embedded.netty.NettyReactiveWebServerFactory;
import org.springframework.boot.web.server.WebServer;
import org.springframework.http.server.reactive.HttpHandler;
import org.springframework.stereotype.Component;
@Component
public class HttpServer
{
@Value("${http-port}")
int mPort ;
@Autowired
HttpHandler mHttpHandler ;
WebServer mWebServer ;
public HttpServer()
{
}
@PostConstruct
void _init()
{
NettyReactiveWebServerFactory fac = new NettyReactiveWebServerFactory(mPort) ;
mWebServer = fac.getWebServer(mHttpHandler) ;
mWebServer.start();
}
@PreDestroy
public void stop()
{
mWebServer.stop() ;
}
}