HTTP 客戶端
Spring Boot 提供了許多與 HTTP 客戶端協同工作的啟動器。本節回答了有關使用它們的問題。
配置 RestTemplate 以使用代理
如 RestTemplate 自定義 中所述,你可以使用 RestTemplateCustomizer 和 RestTemplateBuilder 來構建一個自定義的 RestTemplate。這是建立配置為使用代理的 RestTemplate 的推薦方法。
代理配置的具體細節取決於所使用的底層客戶端請求工廠。
配置 Reactor Netty-based WebClient 使用的 TcpClient
當 Reactor Netty 存在於類路徑中時,會自動配置一個基於 Reactor Netty 的 WebClient。要自定義客戶端對網路連線的處理,請提供一個 ClientHttpConnector bean。以下示例配置了一個 60 秒的連線超時並添加了一個 ReadTimeoutHandler
-
Java
-
Kotlin
import io.netty.channel.ChannelOption;
import io.netty.handler.timeout.ReadTimeoutHandler;
import reactor.netty.http.client.HttpClient;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.client.ReactorResourceFactory;
import org.springframework.http.client.reactive.ClientHttpConnector;
import org.springframework.http.client.reactive.ReactorClientHttpConnector;
@Configuration(proxyBeanMethods = false)
public class MyReactorNettyClientConfiguration {
@Bean
ClientHttpConnector clientHttpConnector(ReactorResourceFactory resourceFactory) {
HttpClient httpClient = HttpClient.create(resourceFactory.getConnectionProvider())
.runOn(resourceFactory.getLoopResources())
.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 60000)
.doOnConnected((connection) -> connection.addHandlerLast(new ReadTimeoutHandler(60)));
return new ReactorClientHttpConnector(httpClient);
}
}
import io.netty.channel.ChannelOption
import io.netty.handler.timeout.ReadTimeoutHandler
import org.springframework.context.annotation.Bean
import org.springframework.context.annotation.Configuration
import org.springframework.http.client.reactive.ClientHttpConnector
import org.springframework.http.client.reactive.ReactorClientHttpConnector
import org.springframework.http.client.ReactorResourceFactory
import reactor.netty.http.client.HttpClient
@Configuration(proxyBeanMethods = false)
class MyReactorNettyClientConfiguration {
@Bean
fun clientHttpConnector(resourceFactory: ReactorResourceFactory): ClientHttpConnector {
val httpClient = HttpClient.create(resourceFactory.connectionProvider)
.runOn(resourceFactory.loopResources)
.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 60000)
.doOnConnected { connection ->
connection.addHandlerLast(ReadTimeoutHandler(60))
}
return ReactorClientHttpConnector(httpClient)
}
}
請注意使用 ReactorResourceFactory 作為連線提供程式和事件迴圈資源。這確保了伺服器接收請求和客戶端發出請求時資源的有效共享。 |