HttpUtils.java 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. package com.ruoyi.common.utils.http;
  2. import java.io.BufferedReader;
  3. import java.io.IOException;
  4. import java.io.InputStream;
  5. import java.io.InputStreamReader;
  6. import java.io.PrintWriter;
  7. import java.net.ConnectException;
  8. import java.net.SocketTimeoutException;
  9. import java.net.URL;
  10. import java.net.URLConnection;
  11. import java.security.cert.X509Certificate;
  12. import javax.net.ssl.HostnameVerifier;
  13. import javax.net.ssl.HttpsURLConnection;
  14. import javax.net.ssl.SSLContext;
  15. import javax.net.ssl.SSLSession;
  16. import javax.net.ssl.TrustManager;
  17. import javax.net.ssl.X509TrustManager;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import com.ruoyi.common.constant.Constants;
  21. import com.ruoyi.common.utils.StringUtils;
  22. /**
  23. * 通用http发送方法
  24. *
  25. * @author ruoyi
  26. */
  27. public class HttpUtils
  28. {
  29. private static final Logger log = LoggerFactory.getLogger(HttpUtils.class);
  30. /**
  31. * 向指定 URL 发送GET方法的请求
  32. *
  33. * @param url 发送请求的 URL
  34. * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
  35. * @return 所代表远程资源的响应结果
  36. */
  37. public static String sendGet(String url, String param)
  38. {
  39. return sendGet(url, param, Constants.UTF8);
  40. }
  41. /**
  42. * 向指定 URL 发送GET方法的请求
  43. *
  44. * @param url 发送请求的 URL
  45. * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
  46. * @param contentType 编码类型
  47. * @return 所代表远程资源的响应结果
  48. */
  49. public static String sendGet(String url, String param, String contentType)
  50. {
  51. StringBuilder result = new StringBuilder();
  52. BufferedReader in = null;
  53. try
  54. {
  55. String urlNameString = StringUtils.isNotBlank(param) ? url + "?" + param : url;
  56. log.info("sendGet - {}", urlNameString);
  57. URL realUrl = new URL(urlNameString);
  58. URLConnection connection = realUrl.openConnection();
  59. connection.setRequestProperty("accept", "*/*");
  60. connection.setRequestProperty("connection", "Keep-Alive");
  61. connection.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
  62. connection.connect();
  63. in = new BufferedReader(new InputStreamReader(connection.getInputStream(), contentType));
  64. String line;
  65. while ((line = in.readLine()) != null)
  66. {
  67. result.append(line);
  68. }
  69. log.info("recv - {}", result);
  70. }
  71. catch (ConnectException e)
  72. {
  73. log.error("调用HttpUtils.sendGet ConnectException, url=" + url + ",param=" + param, e);
  74. }
  75. catch (SocketTimeoutException e)
  76. {
  77. log.error("调用HttpUtils.sendGet SocketTimeoutException, url=" + url + ",param=" + param, e);
  78. }
  79. catch (IOException e)
  80. {
  81. log.error("调用HttpUtils.sendGet IOException, url=" + url + ",param=" + param, e);
  82. }
  83. catch (Exception e)
  84. {
  85. log.error("调用HttpsUtil.sendGet Exception, url=" + url + ",param=" + param, e);
  86. }
  87. finally
  88. {
  89. try
  90. {
  91. if (in != null)
  92. {
  93. in.close();
  94. }
  95. }
  96. catch (Exception ex)
  97. {
  98. log.error("调用in.close Exception, url=" + url + ",param=" + param, ex);
  99. }
  100. }
  101. return result.toString();
  102. }
  103. /**
  104. * 向指定 URL 发送POST方法的请求
  105. *
  106. * @param url 发送请求的 URL
  107. * @param param 请求参数,请求参数应该是 name1=value1&name2=value2 的形式。
  108. * @return 所代表远程资源的响应结果
  109. */
  110. public static String sendPost(String url, String param)
  111. {
  112. PrintWriter out = null;
  113. BufferedReader in = null;
  114. StringBuilder result = new StringBuilder();
  115. try
  116. {
  117. String urlNameString = url;
  118. log.info("sendPost - {}", urlNameString);
  119. URL realUrl = new URL(urlNameString);
  120. URLConnection conn = realUrl.openConnection();
  121. conn.setRequestProperty("accept", "*/*");
  122. conn.setRequestProperty("connection", "Keep-Alive");
  123. conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
  124. conn.setRequestProperty("Accept-Charset", "utf-8");
  125. conn.setRequestProperty("contentType", "utf-8");
  126. conn.setDoOutput(true);
  127. conn.setDoInput(true);
  128. out = new PrintWriter(conn.getOutputStream());
  129. out.print(param);
  130. out.flush();
  131. in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "utf-8"));
  132. String line;
  133. while ((line = in.readLine()) != null)
  134. {
  135. result.append(line);
  136. }
  137. log.info("recv - {}", result);
  138. }
  139. catch (ConnectException e)
  140. {
  141. log.error("调用HttpUtils.sendPost ConnectException, url=" + url + ",param=" + param, e);
  142. }
  143. catch (SocketTimeoutException e)
  144. {
  145. log.error("调用HttpUtils.sendPost SocketTimeoutException, url=" + url + ",param=" + param, e);
  146. }
  147. catch (IOException e)
  148. {
  149. log.error("调用HttpUtils.sendPost IOException, url=" + url + ",param=" + param, e);
  150. }
  151. catch (Exception e)
  152. {
  153. log.error("调用HttpsUtil.sendPost Exception, url=" + url + ",param=" + param, e);
  154. }
  155. finally
  156. {
  157. try
  158. {
  159. if (out != null)
  160. {
  161. out.close();
  162. }
  163. if (in != null)
  164. {
  165. in.close();
  166. }
  167. }
  168. catch (IOException ex)
  169. {
  170. log.error("调用in.close Exception, url=" + url + ",param=" + param, ex);
  171. }
  172. }
  173. return result.toString();
  174. }
  175. public static String sendSSLPost(String url, String param)
  176. {
  177. StringBuilder result = new StringBuilder();
  178. String urlNameString = url + "?" + param;
  179. try
  180. {
  181. log.info("sendSSLPost - {}", urlNameString);
  182. SSLContext sc = SSLContext.getInstance("SSL");
  183. sc.init(null, new TrustManager[] { new TrustAnyTrustManager() }, new java.security.SecureRandom());
  184. URL console = new URL(urlNameString);
  185. HttpsURLConnection conn = (HttpsURLConnection) console.openConnection();
  186. conn.setRequestProperty("accept", "*/*");
  187. conn.setRequestProperty("connection", "Keep-Alive");
  188. conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
  189. conn.setRequestProperty("Accept-Charset", "utf-8");
  190. conn.setRequestProperty("contentType", "utf-8");
  191. conn.setDoOutput(true);
  192. conn.setDoInput(true);
  193. conn.setSSLSocketFactory(sc.getSocketFactory());
  194. conn.setHostnameVerifier(new TrustAnyHostnameVerifier());
  195. conn.connect();
  196. InputStream is = conn.getInputStream();
  197. BufferedReader br = new BufferedReader(new InputStreamReader(is));
  198. String ret = "";
  199. while ((ret = br.readLine()) != null)
  200. {
  201. if (ret != null && !"".equals(ret.trim()))
  202. {
  203. result.append(new String(ret.getBytes("ISO-8859-1"), "utf-8"));
  204. }
  205. }
  206. log.info("recv - {}", result);
  207. conn.disconnect();
  208. br.close();
  209. }
  210. catch (ConnectException e)
  211. {
  212. log.error("调用HttpUtils.sendSSLPost ConnectException, url=" + url + ",param=" + param, e);
  213. }
  214. catch (SocketTimeoutException e)
  215. {
  216. log.error("调用HttpUtils.sendSSLPost SocketTimeoutException, url=" + url + ",param=" + param, e);
  217. }
  218. catch (IOException e)
  219. {
  220. log.error("调用HttpUtils.sendSSLPost IOException, url=" + url + ",param=" + param, e);
  221. }
  222. catch (Exception e)
  223. {
  224. log.error("调用HttpsUtil.sendSSLPost Exception, url=" + url + ",param=" + param, e);
  225. }
  226. return result.toString();
  227. }
  228. private static class TrustAnyTrustManager implements X509TrustManager
  229. {
  230. @Override
  231. public void checkClientTrusted(X509Certificate[] chain, String authType)
  232. {
  233. }
  234. @Override
  235. public void checkServerTrusted(X509Certificate[] chain, String authType)
  236. {
  237. }
  238. @Override
  239. public X509Certificate[] getAcceptedIssuers()
  240. {
  241. return new X509Certificate[] {};
  242. }
  243. }
  244. private static class TrustAnyHostnameVerifier implements HostnameVerifier
  245. {
  246. @Override
  247. public boolean verify(String hostname, SSLSession session)
  248. {
  249. return true;
  250. }
  251. }
  252. }