| package com.ruoyi.common.utils; | 
|   | 
| import okhttp3.*; | 
|   | 
| import javax.net.ssl.SSLContext; | 
| import javax.net.ssl.TrustManager; | 
| import javax.net.ssl.X509TrustManager; | 
| import java.io.IOException; | 
| import java.security.SecureRandom; | 
| import java.security.cert.X509Certificate; | 
|   | 
| public class OkHttpExample { | 
|   | 
|     public static OkHttpClient createUnsafeOkHttpClient() { | 
|   | 
|         SSLContext sslContext; | 
|         X509TrustManager trustManager = null; | 
|         try { | 
|             // 创建一个信任所有证书的 TrustManager | 
|             TrustManager[] trustAllManagers = new TrustManager[]{new X509TrustManager() { | 
|                 @Override | 
|                 public void checkClientTrusted(X509Certificate[] chain, String authType) { | 
|                 } | 
|   | 
|                 @Override | 
|                 public void checkServerTrusted(X509Certificate[] chain, String authType) { | 
|                 } | 
|   | 
|                 @Override | 
|                 public X509Certificate[] getAcceptedIssuers() { | 
|                     return new X509Certificate[0]; | 
|                 } | 
|             }}; | 
|   | 
|             // 保存 TrustManager | 
|             trustManager = (X509TrustManager) trustAllManagers[0]; | 
|   | 
|             // 初始化 SSLContext | 
|             sslContext = SSLContext.getInstance("TLS"); | 
|             sslContext.init(null, trustAllManagers, new SecureRandom()); | 
|         } catch (Exception e) { | 
|             throw new IllegalStateException("Failed to initialize SSLContext", e); | 
|         } | 
|   | 
|         // 创建 OkHttpClient,设置自定义的 SSLContext | 
|         return new OkHttpClient.Builder().sslSocketFactory(sslContext.getSocketFactory(), trustManager) // 直接使用保存的 TrustManager | 
|                 .hostnameVerifier((hostname, session) -> true) // 忽略主机名验证 | 
|                 .build(); | 
|     } | 
|   | 
|   | 
|     public static String sendPostRequest(String url, String jsonBody, String token) throws IOException { | 
|         // 创建 OkHttpClient 实例 | 
|         OkHttpClient client = createUnsafeOkHttpClient(); | 
|   | 
|         // 创建请求体 | 
|         MediaType JSON = MediaType.parse("application/json; charset=utf-8"); | 
|         RequestBody body = RequestBody.create(JSON, jsonBody);  // 修改为这种形式 | 
|         // 创建请求,设置请求头和请求体 | 
|         Request request = new Request.Builder().url(url).addHeader("Authorization", token)// 设置 Token | 
|                 .post(body).build(); | 
|   | 
|         // 执行请求并获取响应 | 
|         try (Response response = client.newCall(request).execute()) { | 
|             if (response.isSuccessful()) { | 
|                 return response.body().string(); // 返回响应体 | 
|             } else { | 
|                 throw new IOException("Unexpected code " + response); | 
|             } | 
|         } | 
|     } | 
|   | 
|   | 
| } |