解決Java處理HTTP請求超時的問題
在發(fā)送POST或GET請求時,返回超時異常處理辦法:
捕獲 SocketTimeoutException | ConnectTimeoutException | ConnectionPoolTimeout 異常
三種異常說明:
SocketTimeoutException:是Java包下拋出的異常,這定義了Socket讀數(shù)據(jù)的超時時間,即從server獲取響應數(shù)據(jù)須要等待的時間;當讀取或者接收Socket超時會拋出SocketTimeoutException。
ConnectTimeoutException:是Apache的HttpClient包拋出的超時異常,定義了通過網(wǎng)絡(luò)與server建立連接的超時時間,Httpclient包中通過一個異步線程去創(chuàng)建與server的socket連接,這就是該socket連接的超時時;
當連接HTTPserver或者等待HttpConnectionManager管理的一個有效連接超時出錯會拋出ConnectionTimeoutException。
ConnectionPoolTimeout:也是Apache的HttpClient包拋出的超時異常,定義了從 ConnectionManager 管理的連接池中取出連接的超時時間;出錯會拋出 ConnectionPoolTimeoutException。
總結(jié):
SocketTimeoutException異常是一個通用的異常,無論是用原生的HTTP請求,還是用Apache下的HttpClient包,在拋出的異常中都需要捕獲 SocketTimeoutException 異常。
例:
public static String doGet(String url, Object params, String contentType) {
try {
return HttpUtils.doGetSend(url, params, contentType);
} catch (SocketTimeoutException | ConnectTimeoutException e) {
e.printStackTrace();
System.out.println("請求連接超時:" + e.getMessage());
} catch (IOException e) {
e.printStackTrace();
System.out.println("請求異常,異常信息:" + e.getMessage());
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
補充:java 發(fā)送http請求(連接超時處理)
業(yè)務背景:
某項目跟第三方公司對接。
業(yè)務描述:
出于數(shù)據(jù)安全考慮,需要從服務器發(fā)送請求,來調(diào)用第三方公司提供的接口。但是該場景是銷售類型,響應時間必須夠快,那么就要設(shè)置響應的超時處理。
不然讓客戶看著圈圈在那里轉(zhuǎn)半天,誰買?
項目架構(gòu):
jdk1.7
spring4.2.9
詳細內(nèi)容:
CloseableHttpClient httpclient = HttpClients.createDefault();
try {
HttpPost httpPost = new HttpPost(要訪問的URL);
//配置超時
RequestConfig requestConfig = RequestConfig.custom()
.setConnectTimeout(5000).setConnectionRequestTimeout(5000)
.setSocketTimeout(5000).build();
httpPost.setConfig(requestConfig);
//設(shè)置post請求參數(shù)
List<NameValuePair> nvps = new ArrayList<NameValuePair>();
nvps.add(new BasicNameValuePair("attr1", 參數(shù)值1));
nvps.add(new BasicNameValuePair("attr2", 參數(shù)值2));
nvps.add(new BasicNameValuePair("attr3", 參數(shù)值3));
……
httpPost.setEntity(new UrlEncodedFormEntity(nvps));
//執(zhí)行post請求
CloseableHttpResponse response = httpclient.execute(httpPost);
// 判斷網(wǎng)絡(luò)連接狀態(tài)碼是否正常(0--200都數(shù)正常)
if(response.getStatusLine().getStatusCode() == HttpStatus.SC_OK){
//獲取響應實體
responseMessage = EntityUtils.toString(response.getEntity(),"utf-8");
System.out.println(responseMessage);
if(responseMessage!=null && !"".equals(responseMessage)){
String data = new String(AESUtil.decrypt(Base64.decode(responseMessage), key),"UTF-8");
String msg = translate_PRE(data,trans_type,transNo);
result.put("msg", msg);
}
}else{
System.out.println("請求未成功響應: "+ response.getStatusLine());
}
} catch (ConnectTimeoutException e) {
System.out.println(api_type+"請求超時");
} catch (ClientProtocolException e) {
System.out.println("請求失敗");
} catch (Exception e) {
e.printStackTrace();
} finally {
//釋放連接
try {
if(httpclient!=null){
httpclient.close();
}
} catch (IOException e) {
System.out.println(api_type+"連接無法關(guān)閉");
}
}
.setConnectTimeout(5000).setConnectionRequestTimeout(5000)
.setSocketTimeout(5000).build();
httpPost.setConfig(requestConfig);
//設(shè)置post請求參數(shù)
List<NameValuePair> nvps = new ArrayList<NameValuePair>();
nvps.add(new BasicNameValuePair("attr1", 參數(shù)值1));
nvps.add(new BasicNameValuePair("attr2", 參數(shù)值2));
nvps.add(new BasicNameValuePair("attr3", 參數(shù)值3));
……
httpPost.setEntity(new UrlEncodedFormEntity(nvps));
//執(zhí)行post請求
CloseableHttpResponse response = httpclient.execute(httpPost);
// 判斷網(wǎng)絡(luò)連接狀態(tài)碼是否正常(0--200都數(shù)正常)
if(response.getStatusLine().getStatusCode() == HttpStatus.SC_OK){
//獲取響應實體
responseMessage = EntityUtils.toString(response.getEntity(),"utf-8");
System.out.println(responseMessage);
if(responseMessage!=null && !"".equals(responseMessage)){
String data = new String(AESUtil.decrypt(Base64.decode(responseMessage), key),"UTF-8");
String msg = translate_PRE(data,trans_type,transNo);
result.put("msg", msg);
}
}else{
System.out.println("請求未成功響應: "+ response.getStatusLine());
}
} catch (ConnectTimeoutException e) {
System.out.println(api_type+"請求超時");
} catch (ClientProtocolException e) {
System.out.println("請求失敗");
} catch (Exception e) {
e.printStackTrace();
} finally {
//釋放連接
try {
if(httpclient!=null){
httpclient.close();
}
} catch (IOException e) {
System.out.println(api_type+"連接無法關(guān)閉");
}
}
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
Spring?Kafka中如何通過參數(shù)配置解決超時問題詳解
這篇文章主要給大家介紹了關(guān)于Spring?Kafka中如何通過參數(shù)配置解決超時問題的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2022-01-01
java實現(xiàn)上傳網(wǎng)絡(luò)圖片到微信臨時素材
這篇文章主要為大家詳細介紹了java實現(xiàn)上傳網(wǎng)絡(luò)圖片到微信臨時素材,網(wǎng)絡(luò)圖片上傳到微信服務器,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07
解決RestTemplate 請求url中包含百分號 會被轉(zhuǎn)義成25的問題
這篇文章主要介紹了解決RestTemplate 請求url中包含百分號 會被轉(zhuǎn)義成25的問題,具有很好的參考價值,希望對大家有所幫助。2021-10-10
Struts2實現(xiàn)文件下載功能代碼分享(文件名中文轉(zhuǎn)碼)
這篇文章主要介紹了Struts2實現(xiàn)文件下載功能代碼分享(文件名中文轉(zhuǎn)碼)的相關(guān)資料,需要的朋友可以參考下2016-06-06
SpringBoot application.yml和bootstrap.yml的區(qū)別
本文主要介紹了SpringBoot application.yml和bootstrap.yml的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04

