spring?webClient配置及使用簡單代碼示例
1.配置
import com.zty.common.util.WebUtils;
import io.netty.channel.ChannelOption;
import io.netty.handler.timeout.ReadTimeoutHandler;
import io.netty.handler.timeout.WriteTimeoutHandler;
import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpHeaders;
import org.springframework.http.MediaType;
import org.springframework.http.client.reactive.ReactorClientHttpConnector;
import org.springframework.web.reactive.function.client.WebClient;
import reactor.netty.http.client.HttpClient;
import reactor.netty.resources.ConnectionProvider;
import java.time.Duration;
/**
* WebClient配置
* @author zty
*/
@Slf4j
@Configuration
public class WebClientConfig {
@Bean
public WebClient webClient(){
//配置固定大小連接池
ConnectionProvider provider = ConnectionProvider
.builder("custom")
// 等待超時時間
.pendingAcquireTimeout(Duration.ofSeconds(10))
// 最大連接數(shù)
.maxConnections(200)
// 最大空閑時間
.maxIdleTime(Duration.ofSeconds(5))
// 最大等待連接數(shù)量
.pendingAcquireMaxCount(-1)
.build();
/**
* doOnBind 當服務器channel即將被綁定的時候調用。
* doOnBound 當服務器channel已經(jīng)被綁定的時候調用。
* doOnChannelInit 當channel初始化的時候被調用。
* doOnConnection 當一個遠程客戶端連接上的時候被調用。
* doOnUnbound 當服務器channel解綁的時候被調用。
*/
HttpClient httpClient = HttpClient.create(provider)
.option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 6000)
.option(ChannelOption.SO_KEEPALIVE, true)
.responseTimeout(Duration.ofSeconds(6))
.keepAlive(true)
//連接成功
.doOnConnected(connection -> connection.addHandlerLast(new ReadTimeoutHandler(6))
.addHandlerLast(new WriteTimeoutHandler(6)))
//每次請求后執(zhí)行flush,防止服務器主動斷開連接
.doAfterRequest((httpClientRequest, connection) -> {
connection.channel().alloc().buffer().release();
connection.channel().flush();
connection.channel().pipeline().flush();
});
return WebClient.builder()
.baseUrl("http://127.0.0.1:8080")
.defaultHeader(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE)
.defaultHeader(HttpHeaders.CONNECTION, "keep-alive")
.clientConnector(new ReactorClientHttpConnector(httpClient))
.build();
}
}2.使用
import com.alibaba.fastjson2.JSON;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
import org.springframework.web.reactive.function.client.WebClient;
import reactor.core.publisher.Mono;
import java.util.HashMap;
/**
* http消息發(fā)送工具
* @author zty
*/
@Slf4j
@Component
public class WebUtils {
@Autowired
WebClient webClient;
@Async
public void post(HashMap<String, Object> message){
// 發(fā)送請求
webClient.post()
// 請求路徑
.uri("/test")
// 攜帶參數(shù)
.bodyValue(JSON.toJSONString(message))
// 獲取響應體
.retrieve()
// 響應數(shù)據(jù)類型轉換
.bodyToMono(String.class)
.doOnError(throwable -> log.info(throwable.getMessage()))
.onErrorResume(e -> Mono.just("Error " + e.getMessage()))
// 異步
.subscribe();
}
}附:一個帶有多個查詢參數(shù)的WebClient使用示例
import org.springframework.web.reactive.function.client.WebClient;
public class ExampleWebClient {
public static void main(String[] args) {
WebClient client = WebClient.create("https://api.example.com");
client.get()
.uri(uriBuilder -> uriBuilder.path("/search")
.queryParam("q", "WebClient")
.queryParam("page", 1)
.queryParam("size", 20)
.build())
.retrieve()
.bodyToMono(String.class)
.subscribe(response -> System.out.println(response));
}
}
在這個示例中,我們使用了uri()方法來構建URI。使用了一個Lambda表達式,在其中的uriBuilder對象(UriBuilder類型)中指定了路徑和查詢參數(shù)。在這個例子中,我們將/search作為路徑,以及三個查詢參數(shù)q、page、size來進行搜索,它們的值依次為WebClient(表示搜索關鍵字為WebClient)、1、20。
最終的URI將會是一個類似于 https://api.example.com/search?q=WebClient&page=1&size=20 的字符串。在發(fā)送請求后,我們將響應體轉換為String類型的Mono對象,并使用subscribe()方法輸出響應內容。
總結
到此這篇關于spring webClient配置及使用的文章就介紹到這了,更多相關spring webClient配置使用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
springboot項目攔截前端請求中的特殊字符串(解決方案)
springboot項目中,需要對前端請求數(shù)據(jù)進行過濾,攔截特殊字符,本文通過實例代碼給大家分享完美解決方案,感興趣的朋友一起看看吧2023-10-10
spring項目如何配置多數(shù)據(jù)源(已上生產(chǎn),親測有效)
這篇文章主要介紹了spring項目如何配置多數(shù)據(jù)源(已上生產(chǎn),親測有效),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
PowerJob的ServerDiscoveryService工作流程源碼解讀
這篇文章主要為大家介紹了PowerJob的ServerDiscoveryService工作流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12
繼承WebMvcConfigurationSupport后自動配置不生效及如何配置攔截器
這篇文章主要介紹了繼承WebMvcConfigurationSupport后自動配置不生效及如何配置攔截器,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11

