From aa925d851857f50eff0556411366690d9a78a0e5 Mon Sep 17 00:00:00 2001 From: 44323 <443237572@qq.com> Date: 星期一, 27 十一月 2023 17:30:26 +0800 Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/PlayPai --- cloud-server-course/src/main/java/com/dsh/course/util/httpClinet/HttpClientUtil.java | 109 ++++++++++++++++++++++++++++-------------------------- 1 files changed, 56 insertions(+), 53 deletions(-) diff --git a/cloud-server-course/src/main/java/com/dsh/course/util/httpClinet/HttpClientUtil.java b/cloud-server-course/src/main/java/com/dsh/course/util/httpClinet/HttpClientUtil.java index 9c588b5..d4b0bfe 100644 --- a/cloud-server-course/src/main/java/com/dsh/course/util/httpClinet/HttpClientUtil.java +++ b/cloud-server-course/src/main/java/com/dsh/course/util/httpClinet/HttpClientUtil.java @@ -51,14 +51,14 @@ /** * 创建一个httpClient对象 */ - private static CloseableHttpClient getHttpCline(){ - return HttpClients.custom() + private static CloseableHttpClient getHttpCline() { + return HttpClients.custom() .setConnectionManager(connectionManager) .disableAutomaticRetries() .build(); } - private static RequestConfig getRequestConfig(){ + private static RequestConfig getRequestConfig() { RequestConfig.Builder builder = RequestConfig.custom(); builder.setSocketTimeout(60000)//3.1设置客户端等待服务端返回数据的超时时间 .setConnectTimeout(30000)//3.2设置客户端发起TCP连接请求的超时时间 @@ -68,34 +68,34 @@ } - /** * 创建一个POST请求实例 - * @param url 请求地址 - * @param params 请求参数 + * + * @param url 请求地址 + * @param params 请求参数 */ - private static CloseableHttpResponse setPostHttpRequset(String url, Map<String, Object> params, Map<String, String> header, String contentType) throws Exception{ + private static CloseableHttpResponse setPostHttpRequset(String url, Map<String, Object> params, Map<String, String> header, String contentType) throws Exception { HttpPost httpPost = new HttpPost(url); httpPost.setConfig(getRequestConfig()); - if(null != header){ - for(String key : header.keySet()){ + if (null != header) { + for (String key : header.keySet()) { httpPost.setHeader(key, header.get(key)); } } List<NameValuePair> list = new ArrayList<>(); - if(null != params){ + if (null != params) { Set<String> keys = params.keySet(); - for(String key : keys){ + for (String key : keys) { list.add(new BasicNameValuePair(key, null == params.get(key) ? null : params.get(key).toString())); } } - switch (contentType){ + switch (contentType) { case "form": httpPost.setEntity(new UrlEncodedFormEntity(list, "UTF-8")); break; case "json": ObjectMapper objectMapper = new ObjectMapper(); - String s =objectMapper.writeValueAsString(params); + String s = objectMapper.writeValueAsString(params); httpPost.setEntity(new StringEntity(s, ContentType.create(ContentType.APPLICATION_JSON.getMimeType(), Charset.forName("UTF-8")))); break; } @@ -105,23 +105,24 @@ /** * 获取get请求实例 - * @param url 请求地址 - * @param params 请求参数 + * + * @param url 请求地址 + * @param params 请求参数 */ - private static CloseableHttpResponse setGetHttpRequset(String url, Map<String, Object> params, Map<String, String> header) throws Exception{ + private static CloseableHttpResponse setGetHttpRequset(String url, Map<String, Object> params, Map<String, String> header) throws Exception { StringBuffer sb = new StringBuffer(); String p = ""; - if(null != params){ + if (null != params) { Set<String> keys = params.keySet(); - for(String key : keys){ + for (String key : keys) { sb.append(key + "=" + params.get(key) + "&"); } p = "?" + sb.substring(0, sb.length() - 1); } HttpGet httpGet = new HttpGet(url + p); httpGet.setConfig(getRequestConfig()); - if(null != header){ - for(String key : header.keySet()){ + if (null != header) { + for (String key : header.keySet()) { httpGet.setHeader(key, header.get(key)); } } @@ -131,19 +132,20 @@ /** * 发送http请求 - * @param mothed "GET、POST、PUT、HEAD、DELETE、HEAD、OPTIONS" - * @param url 请求地址 - * @param params 请求参数 - * @param header 请求头 - * @param contentType 参数请求方式form/json + * + * @param mothed "GET、POST、PUT、HEAD、DELETE、HEAD、OPTIONS" + * @param url 请求地址 + * @param params 请求参数 + * @param header 请求头 + * @param contentType 参数请求方式form/json * @return */ - public static HttpResult pushHttpRequset(String mothed, String url, Map<String, Object> params, Map<String, String> header, String contentType) throws Exception{ + public static HttpResult pushHttpRequset(String mothed, String url, Map<String, Object> params, Map<String, String> header, String contentType) throws Exception { String randome = UUID.randomUUID().toString(); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.S"); logger.info(sdf.format(new Date()) + "----(" + randome + ")请求参数:" + JSON.toJSONString(params)); CloseableHttpResponse httpResponse = null; - switch (mothed){ + switch (mothed) { case "GET": httpResponse = setGetHttpRequset(url, params, header); break; @@ -162,15 +164,16 @@ /** * 发送XML请求 - * @param url 请求地址 - * @param xml XML数据 - * @param header 自定义请求头 + * + * @param url 请求地址 + * @param xml XML数据 + * @param header 自定义请求头 * @return */ - public static HttpResult pushHttpRequsetXml(String url, String xml, Map<String, String> header) throws Exception{ + public static HttpResult pushHttpRequsetXml(String url, String xml, Map<String, String> header) throws Exception { HttpPost httpPost = new HttpPost(url); httpPost.setConfig(getRequestConfig()); - for(String key : header.keySet()){ + for (String key : header.keySet()) { httpPost.setHeader(key, header.get(key)); } httpPost.setHeader("Content-Type", "application/xml"); @@ -184,21 +187,21 @@ } - /** * 请求https发送XML请求 - * @param url 接口路径 - * @param xml 内容 - * @param header 请求头 - * @param certPassword 证书密码 - * @param certPath 证书路径 - * @param certType 证书类型 + * + * @param url 接口路径 + * @param xml 内容 + * @param header 请求头 + * @param certPassword 证书密码 + * @param certPath 证书路径 + * @param certType 证书类型 * @return * @throws Exception */ - public static String pushHttpsRequsetXml(String url, String xml, Map<String, String> header, String certPassword, String certPath, String certType) throws Exception{ + public static String pushHttpsRequsetXml(String url, String xml, Map<String, String> header, String certPassword, String certPath, String certType) throws Exception { HttpPost httpPost = new HttpPost(url); - for(String key : header.keySet()){ + for (String key : header.keySet()) { httpPost.setHeader(key, header.get(key)); } httpPost.setHeader("Content-Type", "application/xml"); @@ -206,9 +209,9 @@ CloseableHttpClient httpCline = initCert(certPassword, certPath, certType); CloseableHttpResponse httpResponse = httpCline.execute(httpPost); String content = null; - if(httpResponse.getStatusLine().getStatusCode() == 200){ + if (httpResponse.getStatusLine().getStatusCode() == 200) { content = EntityUtils.toString(httpResponse.getEntity(), "UTF-8"); - }else{ + } else { content = "返回状态码:" + httpResponse.getStatusLine() + "。" + EntityUtils.toString(httpResponse.getEntity()); } close(httpResponse); @@ -219,9 +222,10 @@ /** * 初始化https对象(带证书) - * @param key 证书密码 - * @param certPath 证书路径 - * @param certType 证书类型 + * + * @param key 证书密码 + * @param certPath 证书路径 + * @param certType 证书类型 * @throws Exception */ private static CloseableHttpClient initCert(String key, String certPath, String certType) throws Exception { @@ -234,30 +238,29 @@ } SSLContext sslcontext = SSLContexts.custom().loadKeyMaterial(keyStore, key.toCharArray()).build(); SSLConnectionSocketFactory sslsf = - new SSLConnectionSocketFactory(sslcontext, new String[] {"TLSv1"}, null, + new SSLConnectionSocketFactory(sslcontext, new String[]{"TLSv1"}, null, SSLConnectionSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER); return HttpClients.custom().setSSLSocketFactory(sslsf).build(); } - /** * 关闭资源 */ - private static void close(CloseableHttpResponse httpResponse){ + private static void close(CloseableHttpResponse httpResponse) { try { - if(null != httpResponse){ + if (null != httpResponse) { EntityUtils.consume(httpResponse.getEntity());//此处高能,通过源码分析,由EntityUtils是否回收HttpEntity httpResponse.close(); } } catch (Exception e) { e.printStackTrace(); - }finally { + } finally { try { - if(null != httpResponse){ + if (null != httpResponse) { httpResponse.close(); } - }catch (Exception e){ + } catch (Exception e) { e.printStackTrace(); } } -- Gitblit v1.7.1