亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot使用OkHttp完成高效網絡請求詳解

 更新時間:2025年03月28日 10:55:45   作者:小馬不敲代碼  
OkHttp 是一個高效的 HTTP 客戶端,支持同步和異步請求,且具備自動處理 cookie、緩存和連接池等高級功能,下面我們來看看SpringBoot如何利用 OkHttp 完成高效網絡請求吧

一、OkHttp 簡介

OkHttp 是一個高效的 HTTP 客戶端,它支持同步和異步請求,且具備自動處理 cookie、緩存和連接池等高級功能。

與 Java 原生的 HttpURLConnection 和 Apache 的 HttpClient 相比,OkHttp 的 API 設計更加人性化,使用起來也更加方便。

二、在 Spring Boot 中集成 OkHttp

首先,我們需要在 Spring Boot 項目中引入 OkHttp 的依賴。

在 pom.xml 文件中添加以下依賴:

<dependency>
    <groupId>com.squareup.okhttp3</groupId>
    <artifactId>okhttp</artifactId>
    <version>4.9.3</version> <!-- 注意:版本號可能有所更新,請根據實際情況選擇 -->
</dependency>

三、封裝 OkHttp 客戶端工具類

為了方便在項目中統(tǒng)一管理和使用 OkHttp 客戶端,我們可以將其封裝成一個工具類。

這個工具類將負責初始化 OkHttpClient 實例、構建請求、處理響應等任務。

3.1 初始化 OkHttpClient

在工具類中,我們使用單例模式來初始化 OkHttpClient 實例,并設置一些全局的配置,如連接超時、讀寫超時等。

import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okio.Buffer;

import javax.net.ssl.SSLContext;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import java.io.IOException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import java.util.concurrent.TimeUnit;

public class OkHttpUtil {
    
    private static final OkHttpClient OK_HTTP_CLIENT;

    static {
        TrustManager[] trustManagers = newTrustManager[]{
                newX509TrustManager() {
                    @Override
                    publicvoidcheckClientTrusted(X509Certificate[] chain, String authType)throws CertificateException {
                    }

                    @Override
                    publicvoidcheckServerTrusted(X509Certificate[] chain, String authType)throws CertificateException {
                    }

                    @Override
                    public X509Certificate[] getAcceptedIssuers() {
                        returnnewX509Certificate[]{};
                    }
                }
        };

        try {
            SSLContextsslContext= SSLContext.getInstance("SSL");
            sslContext.init(null, trustManagers, newjava.security.SecureRandom());

            OK_HTTP_CLIENT = newOkHttpClient.Builder()
                    .connectTimeout(15, TimeUnit.SECONDS)
                    .writeTimeout(20, TimeUnit.SECONDS)
                    .readTimeout(20, TimeUnit.SECONDS)
                    .sslSocketFactory(sslContext.getSocketFactory(), (X509TrustManager) trustManagers[0])
                    .hostnameVerifier((hostname, session) -> true)
                    .build();
        } catch (Exception e) {
            thrownewRuntimeException(e);
        }
    }

    // 省略其他方法...
}

在這里,我們使用了自定義的 TrustManager 來忽略 SSL 證書驗證,這通常用于開發(fā)和測試環(huán)境。

在生產環(huán)境中,應該使用正確的證書驗證機制。

3.2 構建請求

接下來,我們需要在工具類中提供構建請求的方法。

這些方法將允許用戶設置請求的 URL、參數、頭部等信息。

import okhttp3.FormBody;
import okhttp3.MediaType;
import okhttp3.Request;
import okhttp3.RequestBody;

import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Objects;

public class OkHttpUtil {
    
    // ... 省略其他代碼

    private String url;
    private Map<String, String> headers = newLinkedHashMap<>();
    private Map<String, Object> params = newLinkedHashMap<>();
    private Request.Builder requestBuilder;

    privat eOkHttpUtil() {
        // 可以在這里添加一些全局的請求頭部,比如 User-Agent
        this.headers.put("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36");
    }

    public static OkHttpUtil builder() {
        returnnewOkHttpUtil();
    }

    public OkHttpUtil url(String url) {
        this.url = url;
        returnthis;
    }

    public OkHttpUtil addParam(String key, String value) {
        this.params.put(key, value);
        returnthis;
    }

    public OkHttpUtil addHeader(String key, String value) {
        this.headers.put(key, value);
        returnthis;
    }

    public OkHttpUtil initGet() {
        this.requestBuilder = newRequest.Builder().get();
        StringBuilder urlBuilder=newStringBuilder(this.url);
        if (!this.params.isEmpty()) {
            urlBuilder.append("?");
            this.params.forEach((k, v) -> urlBuilder.append(k).append("=").append(v).append("&"));
            urlBuilder.deleteCharAt(urlBuilder.length() - 1);
        }
        this.requestBuilder.url(urlBuilder.toString());
        returnthis;
    }

    public OkHttpUtil initPost(boolean isJson) {
        RequestBody requestBody;
        if (isJson) {
            Stringjson="";
            if (!this.params.isEmpty()) {
                // 這里需要使用合適的 JSON 庫將 Map 轉換為 JSON 字符串
                // 例如:json = JSON.toJSONString(this.params);
                // 注意:實際代碼中需要引入 JSON 庫,并處理相關的依賴和異常
                // 為簡化示例,這里省略了 JSON 轉換的代碼
            }
            requestBody = RequestBody.create(json, MediaType.parse("application/json; charset=utf-8"));
        } else {
            FormBody.Builder formBuilder=newFormBody.Builder();
            this.params.forEach((k, v) -> formBuilder.add(k, v.toString()));
            requestBody = formBuilder.build();
        }
        this.requestBuilder = newRequest.Builder().post(requestBody).url(this.url);
        returnthis;
    }

    // ... 省略其他方法...
}

3.3 同步與異步請求

最后,我們需要在工具類中提供同步和異步請求的方法。

這些方法將負責發(fā)送請求并處理響應。

import okhttp3.Call;
import okhttp3.Callback;
import okhttp3.Response;

public class OkHttpUtil {
    
    // ... 省略其他代碼

    public String sync() {
        try {
            Request request=this.requestBuilder.build();
            this.headers.forEach(request::addHeader);
            Response response= OK_HTTP_CLIENT.newCall(request).execute();
            if (response.isSuccessful()) {
                return response.body().string();
            } else {
                return"請求失敗,狀態(tài)碼:" + response.code();
            }
        } catch (IOException e) {
            e.printStackTrace();
            return"請求失敗,異常:" + e.getMessage();
        }
    }

    public String async() {
        final StringBuffer buffer=newStringBuffer();
        Request request=this.requestBuilder.build();
        this.headers.forEach(request::addHeader);
        OK_HTTP_CLIENT.newCall(request).enqueue(newCallback() {
            @Override
            public void onFailure(Call call, IOException e) {
                buffer.append("請求出錯:").append(e.getMessage());
            }

            @Override
            public void onResponse(Call call, Response response)throws IOException {
                if (response.isSuccessful()) {
                    buffer.append(response.body().string());
                } else {
                    buffer.append("請求失敗,狀態(tài)碼:").append(response.code());
                }
            }
        });
        // 注意:這里返回的是一個空字符串或者是一個表示請求正在進行的提示
        // 因為異步請求是非阻塞的,所以不能直接返回最終的響應結果
        // 實際應用中,可以通過回調接口或者其他機制來處理異步請求的響應
    }
}

四、優(yōu)化與擴展

4.1 添加請求頭

在工具類中添加方法,支持自定義請求頭:

public OkHttpUtil addHeader(String key, String value) {
    okHttpClient = okHttpClient.newBuilder()
            .addInterceptor(chain -> {
                Requestoriginal= chain.request();
                RequestnewRequest= original.newBuilder()
                        .header(key, value)
                        .build();
                return chain.proceed(newRequest);
            })
            .build();
    returnthis;
}

4.2 處理 HTTPS 請求

如果需要支持 HTTPS 請求,可以在工具類中添加 SSL 配置:

private static SSLSocketFactory createSSLSocketFactory() {
    try {
        SSLContextsslContext= SSLContext.getInstance("SSL");
        sslContext.init(null, newTrustManager[]{newX509TrustManager() {
            @Override
            publicvoidcheckClientTrusted(X509Certificate[] chain, String authType) {}

            @Override
            publicvoidcheckServerTrusted(X509Certificate[] chain, String authType) {}

            @Override
            public X509Certificate[] getAcceptedIssuers() {
                returnnewX509Certificate[]{};
            }
        }}, newSecureRandom());
        return sslContext.getSocketFactory();
    } catch (Exception e) {
        thrownewRuntimeException(e);
    }
}

然后在初始化 OkHttpClient 時使用:

okHttpClient = new OkHttpClient.Builder()
        .sslSocketFactory(createSSLSocketFactory(), newX509TrustManager() {
            @Override
            publicvoidcheckClientTrusted(X509Certificate[] chain, String authType) {}

            @Override
            publicvoidcheckServerTrusted(X509Certificate[] chain, String authType) {}

            @Override
            public X509Certificate[] getAcceptedIssuers() {
                returnnewX509Certificate[]{};
            }
        })
        .build();

以上就是SpringBoot使用OkHttp完成高效網絡請求詳解的詳細內容,更多關于SpringBoot OkHttp網絡請求的資料請關注腳本之家其它相關文章!

相關文章

  • 利用logback 設置不同包下的日志級別

    利用logback 設置不同包下的日志級別

    這篇文章主要介紹了利用logback 設置不同包下的日志級別,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • Spring源碼解析 Bean屬性填充

    Spring源碼解析 Bean屬性填充

    這篇文章主要介紹了Spring源碼解析 Bean屬性填充,文章圍繞主題展開想詳細的內容詳情,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-07-07
  • Spring初始化與銷毀順序案例演示詳解

    Spring初始化與銷毀順序案例演示詳解

    這篇文章主要介紹了SpringBoot中的Bean的初始化與銷毀順序,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Java 靜態(tài)綁定與動態(tài)綁定深入分析

    Java 靜態(tài)綁定與動態(tài)綁定深入分析

    這篇文章主要介紹了Java 靜態(tài)綁定與動態(tài)綁定深入分析的相關資料,這里對java 的動態(tài)綁定和靜態(tài)綁定做了詳細的介紹,對其進行總結整理,需要的朋友可以參考下
    2016-11-11
  • 詳解Java程序讀取properties配置文件的方法

    詳解Java程序讀取properties配置文件的方法

    這篇文章主要介紹了Java讀取properties配置文件的方法講解,properties可以被看作是Java世界的ini,Java中有Properties可以操作它,需要的朋友可以參考下
    2016-04-04
  • mybatis-plus使用generator實現逆向工程

    mybatis-plus使用generator實現逆向工程

    mybatis-plus-generator在3.5.0以及以后的版本使用新的方式逆向生成代碼,本文主要介紹了mybatis-plus使用generator實現逆向工程,具有一定的參考價值,感興趣的可以了解一下
    2022-05-05
  • Spring AOP的幾種實現方式總結

    Spring AOP的幾種實現方式總結

    本篇文章主要介紹了Spring AOP的幾種實現方式總結,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • Presto自定義函數@SqlNullable引發(fā)問題詳解

    Presto自定義函數@SqlNullable引發(fā)問題詳解

    這篇文章主要為大家介紹了Presto自定義函數@SqlNullable引發(fā)問題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • maven環(huán)境變量配置講解

    maven環(huán)境變量配置講解

    這篇文章主要介紹了maven環(huán)境變量配置講解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-08-08
  • mybatisPlus批量插入優(yōu)化加快性能

    mybatisPlus批量插入優(yōu)化加快性能

    這篇文章主要介紹了mybatisPlus批量插入優(yōu)化加快性能,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-12-12

最新評論