/**
* POST請求(帶json參數)
* @param url 請求地址
* @param socketTimeout 響應超時時間,根據業務而定,單位毫秒;如果訪問一個接口,多少時間內無法返回數據,就直接放棄此次調用
* @param jsonParam json參數
* @param headerMap 請求頭
* @return
*/
public static String doHeaderPostJson(String url, int socketTimeout, Map<String, String> headerMap, String jsonParam) {
// 創建Httpclient對象
CloseableHttpClient httpClient = HttpClients.createDefault();
CloseableHttpResponse response = null;
String resultString = "";
try {
// 創建Http Post請求
HttpPost httpPost = new HttpPost(url);
// 設置請求超時
RequestConfig requestConfig = RequestConfig.custom()
// 設置連接超時時間,單位毫秒。
.setConnectTimeout(5000)
// 從連接池獲取到連接的超時,單位毫秒。
.setConnectionRequestTimeout(1000)
// 請求獲取數據的超時時間,單位毫秒; 如果訪問一個接口,多少時間內無法返回數據,就直接放棄此次調用。
.setSocketTimeout(socketTimeout).build();
httpPost.setConfig(requestConfig);
//創建頭信息
headerMap.entrySet().forEach(entry->httpPost.addHeader(entry.getKey(), entry.getValue()));
// 創建請求內容
if (StringUtils.isNotBlank(jsonParam)) {
StringEntity entity = new StringEntity(jsonParam, ContentType.APPLICATION_JSON);
httpPost.setEntity(entity);
}
// 執行http請求
response = httpClient.execute(httpPost);
resultString = EntityUtils.toString(response.getEntity(), "utf-8");
} catch (SocketTimeoutException e) {
log.error(e.getMessage(), e);
log.info("響應超時!!!");
} catch (Exception e) {
log.error(e.getMessage(), e);
} finally {
// 釋放資源
try {
httpClient.close();
if (null != response) {
response.close();
}
} catch (IOException e) {
log.error(e.getMessage(), e);
}
}
return resultString;
}
/**
* get請求帶參數
* @param url 地址
* @param param 參數
* @param header 請求頭
* @return
*/
public static String doGetHeader(String url, Map<String, String> header , Map<String, String> param) {
// 創建Httpclient對象
CloseableHttpClient httpclient = HttpClients.createDefault();
String resultString = "";
CloseableHttpResponse response = null;
try {
// 創建uri
URIBuilder builder = new URIBuilder(url);
if (param != null) {
for (String key : param.keySet()) {
builder.addParameter(key, param.get(key));
}
}
URI uri = builder.build();
HttpGet httpGet = new HttpGet(uri);
if (header != null) {
for (String key : header.keySet()) {
httpGet.addHeader(key, header.get(key));
}
}
response = httpclient.execute(httpGet);
if (response.getStatusLine().getStatusCode() == 200) {
resultString = EntityUtils.toString(response.getEntity(), "UTF-8");
}
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (response != null) {
response.close();
}
httpclient.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return resultString;
}
// 下面的轉自 https://www.cnblogs.com/htyjlitm/p/10036292.html
package test.huatu.pen.util;
import java.io.IOException;
import org.apache.http.HttpEntity;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpDelete;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpPut;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.apache.log4j.BasicConfigurator;
import org.apache.log4j.Logger;
public class HttpRequestUtil {
private static Logger logger = Logger.getLogger(HttpRequestUtil.class);
/**
* 原生字符串發送get請求
*
* @param url
* @return
* @throws IOException
* @throws ClientProtocolException
*/
public static String doGet(String url, String token) {
BasicConfigurator.configure();
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpGet httpGet = new HttpGet(url);
httpGet.setHeader("Content-type", "application/json");
httpGet.setHeader("DataEncoding", "UTF-8");
httpGet.setHeader("token", token);
RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(35000).setConnectionRequestTimeout(35000).setSocketTimeout(60000).build();
httpGet.setConfig(requestConfig);
CloseableHttpResponse httpResponse = null;
try {
httpResponse = httpClient.execute(httpGet);
HttpEntity entity = httpResponse.getEntity();
String result = EntityUtils.toString(entity);
logger.info("請求成功");
return result;
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (httpResponse != null) {
try {
httpResponse.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != httpClient) {
try {
httpClient.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return null;
}
/**
* 原生字符串發送post請求
*
* @param url
* @param jsonStr
* @return
* @throws IOException
*/
public static String doPost(String url, String token, String jsonStr) {
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpPost httpPost = new HttpPost(url);
RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(35000).setConnectionRequestTimeout(35000).setSocketTimeout(60000).build();
httpPost.setConfig(requestConfig);
httpPost.setHeader("Content-type", "application/json");
httpPost.setHeader("DataEncoding", "UTF-8");
httpPost.setHeader("token", token);
CloseableHttpResponse httpResponse = null;
try {
httpPost.setEntity(new StringEntity(jsonStr));
httpResponse = httpClient.execute(httpPost);
HttpEntity entity = httpResponse.getEntity();
String result = EntityUtils.toString(entity);
return result;
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (httpResponse != null) {
try {
httpResponse.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != httpClient) {
try {
httpClient.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return null;
}
/**
* 原生字符串發送put請求
*
* @param url
* @param token
* @param jsonStr
* @return
* @throws ClientProtocolException
* @throws IOException
*/
public static String doPut(String url, String token, String jsonStr) {
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpPut httpPut = new HttpPut(url);
RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(35000).setConnectionRequestTimeout(35000).setSocketTimeout(60000).build();
httpPut.setConfig(requestConfig);
httpPut.setHeader("Content-type", "application/json");
httpPut.setHeader("DataEncoding", "UTF-8");
httpPut.setHeader("token", token);
CloseableHttpResponse httpResponse = null;
try {
httpPut.setEntity(new StringEntity(jsonStr));
httpResponse = httpClient.execute(httpPut);
HttpEntity entity = httpResponse.getEntity();
String result = EntityUtils.toString(entity);
return result;
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (httpResponse != null) {
try {
httpResponse.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != httpClient) {
try {
httpClient.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return null;
}
/**
* 發送delete請求
*
* @param url
* @param token
* @param jsonStr
* @return
* @throws ClientProtocolException
* @throws IOException
*/
public static String doDelete(String url, String token, String jsonStr) {
CloseableHttpClient httpClient = HttpClients.createDefault();
HttpDelete httpDelete = new HttpDelete(url);
RequestConfig requestConfig = RequestConfig.custom().setConnectTimeout(35000).setConnectionRequestTimeout(35000).setSocketTimeout(60000).build();
httpDelete.setConfig(requestConfig);
httpDelete.setHeader("Content-type", "application/json");
httpDelete.setHeader("DataEncoding", "UTF-8");
httpDelete.setHeader("token", token);
CloseableHttpResponse httpResponse = null;
try {
httpResponse = httpClient.execute(httpDelete);
HttpEntity entity = httpResponse.getEntity();
String result = EntityUtils.toString(entity);
return result;
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (httpResponse != null) {
try {
httpResponse.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if (null != httpClient) {
try {
httpClient.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return null;
}
/**
* 忽略ssl證書驗證
* @return
*/
public static CloseableHttpClient createIgnoreSSLHttpClient() {
try {
SSLContext sslContext = new SSLContextBuilder().loadTrustMaterial(null, new TrustStrategy() {
@Override
public boolean isTrusted(X509Certificate[] chain,
String authType) throws CertificateException {
return true;
}
}).build();
SSLConnectionSocketFactory sslConnectionSocketFactory = new SSLConnectionSocketFactory(sslContext, NoopHostnameVerifier.INSTANCE);
return HttpClients.custom().setSSLSocketFactory(sslConnectionSocketFactory).build();
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* 創建忽略ssl證書驗證的Httpclient對象
* POST請求(帶json參數)
* @param url 請求地址
* @param socketTimeout 響應超時時間,根據業務而定,單位毫秒;如果訪問一個接口,多少時間內無法返回數據,就直接放棄此次調用
* @param jsonParam json參數
* @return
*/
public static String doHeaderPostJson(String url, int socketTimeout, Map<String, String> headerMap, String jsonParam) {
// 創建忽略ssl證書驗證的Httpclient對象
CloseableHttpClient httpClient = createIgnoreSSLHttpClient();
CloseableHttpResponse response = null;
String resultString = "";
try {
// 創建Http Post請求
HttpPost httpPost = new HttpPost(url);
// 設置請求超時
RequestConfig requestConfig = RequestConfig.custom()
// 設置連接超時時間,單位毫秒。
.setConnectTimeout(50000)
// 從連接池獲取到連接的超時,單位毫秒。
.setConnectionRequestTimeout(10000)
// 請求獲取數據的超時時間,單位毫秒; 如果訪問一個接口,多少時間內無法返回數據,就直接放棄此次調用。
.setSocketTimeout(socketTimeout).build();
httpPost.setConfig(requestConfig);
//創建頭信息
headerMap.entrySet().forEach(entry->httpPost.addHeader(entry.getKey(), entry.getValue()));
// 創建請求內容
StringEntity entity = new StringEntity(jsonParam, ContentType.APPLICATION_JSON);
httpPost.setEntity(entity);
// 執行http請求
response = httpClient.execute(httpPost);
resultString = EntityUtils.toString(response.getEntity(), "utf-8");
} catch (SocketTimeoutException e) {
log.error(e.getMessage(), e);
log.info("響應超時!!!");
} catch (Exception e) {
log.error(e.getMessage(), e);
} finally {
// 釋放資源
try {
httpClient.close();
if (null != response) {
response.close();
}
} catch (IOException e) {
log.error(e.getMessage(), e);
}
}
return resultString;
}
}