一个封装的使用Apache HttpClient进行Http请求(GET、POST、PUT等)的类。
2023-09-11 14:17:56 时间
一个封装的使用Apache HttpClient进行Http请求(GET、POST、PUT等)的类。
import com.qunar.payment.gateway.front.channel.mpgs.po.HttpReqEntity; import org.apache.http.HttpHeaders; import org.apache.http.auth.AuthScope; import org.apache.http.auth.UsernamePasswordCredentials; import org.apache.http.client.CredentialsProvider; import org.apache.http.client.config.RequestConfig; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpPut; import org.apache.http.client.methods.HttpUriRequest; import org.apache.http.conn.ssl.NoopHostnameVerifier; import org.apache.http.conn.ssl.SSLConnectionSocketFactory; import org.apache.http.entity.StringEntity; import org.apache.http.impl.client.BasicCredentialsProvider; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; import org.springframework.http.HttpMethod; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManager; import javax.net.ssl.X509TrustManager; import java.io.IOException; import java.security.KeyManagementException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.cert.X509Certificate; /** * User:xfyou Date:2017/11/23 10:50 */ public class HttpUtil { private HttpUtil() { } private static CredentialsProvider credentialsProvider; private static final SSLConnectionSocketFactory SOCKET_FACTORY = getSocketFactory(); private static final NoopHostnameVerifier NO_OP = new NoopHostnameVerifier(); public static String execute(HttpReqEntity httpReqEntity) throws IOException { CloseableHttpClient httpclient = getClosableHttpClient(httpReqEntity); CloseableHttpResponse response = null; try { response = httpclient.execute(getHttpUriRequest(httpReqEntity)); return EntityUtils.toString(response.getEntity()); } finally { try { if (null != response) response.close(); if (null != httpclient) httpclient.close(); } catch (IOException ignored) { } } } private static TrustManager getTrustManagers() { return new X509TrustManager() { public X509Certificate[] getAcceptedIssuers() { return null; } public void checkClientTrusted(X509Certificate[] certs, String authType) { } public void checkServerTrusted(X509Certificate[] certs, String authType) { } }; } private static SSLConnectionSocketFactory getSocketFactory() { SSLContext sslContext; try { sslContext = SSLContext.getInstance(MpgsConstant.SECURITYPROTOCOL_VERSION_TLS_1_2); } catch (NoSuchAlgorithmException e) { return null; } try { sslContext.init(null, new TrustManager[]{getTrustManagers()}, new SecureRandom()); } catch (KeyManagementException e) { return null; } return new SSLConnectionSocketFactory(sslContext); } private static CloseableHttpClient getClosableHttpClient(HttpReqEntity entity) { return HttpClients.custom() .setSSLSocketFactory(SOCKET_FACTORY) .setSSLHostnameVerifier(NO_OP) .setDefaultCredentialsProvider(getCredentialsProvider(entity.getCredUserName(), entity.getCredPasswd())) .build(); } private static HttpPut getHttpPut(String requestUrl, String requestMessage, RequestConfig config) { HttpPut httpPut = new HttpPut(requestUrl); httpPut.setConfig(config); httpPut.addHeader(HttpHeaders.CONTENT_TYPE, MpgsConstant.CONTENTTYPE_JSON); httpPut.setEntity(new StringEntity(requestMessage, MpgsConstant.CHARSET_UTF8)); return httpPut; } private static HttpGet getHttpGet(String requestUrl, RequestConfig config) { HttpGet httpGet = new HttpGet(requestUrl); httpGet.setConfig(config); return httpGet; } private static HttpUriRequest getHttpUriRequest(HttpReqEntity entity) { return entity.getHttpMethod() == HttpMethod.GET ? getHttpGet(entity.getRequestUrl(), entity.getRequestConfig()) : getHttpPut(entity.getRequestUrl(), entity.getRequestMessage(), entity.getRequestConfig()); } private static CredentialsProvider getCredentialsProvider(String userName, String passwd) { if (null == credentialsProvider) { synchronized (HttpUtil.class) { if (null == credentialsProvider) { CredentialsProvider credsProvider = new BasicCredentialsProvider(); credsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials(userName, passwd)); credentialsProvider = credsProvider; } } } return credentialsProvider; } }
相关文章
- <转载>apache 配置 http://www.blogjava.net/bukebushuo/articles/229103.html
- 在Apache Struts中利用OGNL注入
- 使用命令进行Apache Kafka操作
- Apache中KeepAlive 配置
- Apache的编译安装error: APR not found. Please read the documentation
- Apache RocketMQ 荣获 2021 中国开源云联盟优秀开源项目
- 性能测试:监控web服务器--apache
- 数据湖之Hudi(14):Apache Hudi 基本概念
- SAP Hybris安装包里自带的apache ant
- Atitit 文件存储标准化api 总结 目录 1. 操作系统,进行操作1 1.1. FileUtils类的应用1 1.2. 各大api 比较2 2. Java。Io用apache的commo
- Atitit. Class 元数据的反射操作 api apache 工具
- MRS +Apache Zeppelin,让数据分析更便捷
- Apache工具包方法——Hex.encodeHexString(byte[] data)源码浅析
- org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[]
- 【消息中间件】Apache Kafka 教程
- springboot整合Mybatis提示org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)