| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 |
- package com.izouma.dingtalk.utils;
- import com.izouma.dingtalk.OApiException;
- import com.alibaba.fastjson.JSON;
- import com.alibaba.fastjson.JSONObject;
- import org.apache.commons.io.FileUtils;
- import org.apache.http.HttpEntity;
- 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.HttpPost;
- import org.apache.http.client.protocol.HttpClientContext;
- import org.apache.http.entity.ContentType;
- import org.apache.http.entity.StringEntity;
- import org.apache.http.entity.mime.MultipartEntityBuilder;
- import org.apache.http.entity.mime.content.FileBody;
- import org.apache.http.impl.client.CloseableHttpClient;
- import org.apache.http.impl.client.HttpClients;
- import org.apache.http.impl.client.RedirectLocations;
- import org.apache.http.protocol.BasicHttpContext;
- import org.apache.http.protocol.HttpContext;
- import org.apache.http.util.EntityUtils;
- import java.io.File;
- import java.io.IOException;
- import java.net.URI;
- /**
- * HTTP请求封装,建议直接使用sdk的API
- */
- public class HttpHelper {
- public static JSONObject httpGet(String url) throws OApiException{
- HttpGet httpGet = new HttpGet(url);
- CloseableHttpResponse response = null;
- CloseableHttpClient httpClient = HttpClients.createDefault();
- RequestConfig requestConfig = RequestConfig.custom().
- setSocketTimeout(2000).setConnectTimeout(2000).build();
- httpGet.setConfig(requestConfig);
- try {
- response = httpClient.execute(httpGet, new BasicHttpContext());
- if (response.getStatusLine().getStatusCode() != 200) {
- System.out.println("request url failed, http code=" + response.getStatusLine().getStatusCode()
- + ", url=" + url);
- return null;
- }
- HttpEntity entity = response.getEntity();
- if (entity != null) {
- String resultStr = EntityUtils.toString(entity, "utf-8");
- JSONObject result = JSON.parseObject(resultStr);
- if (result.getInteger("errcode") == 0) {
- return result;
- } else {
- System.out.println("request url=" + url + ",return value=");
- System.out.println(resultStr);
- int errCode = result.getInteger("errcode");
- String errMsg = result.getString("errmsg");
- throw new OApiException(errCode, errMsg);
- }
- }
- } catch (IOException e) {
- System.out.println("request url=" + url + ", exception, msg=" + e.getMessage());
- e.printStackTrace();
- } finally {
- if (response != null) try {
- response.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- return null;
- }
-
-
- public static JSONObject httpPost(String url, Object data) throws OApiException {
- HttpPost httpPost = new HttpPost(url);
- CloseableHttpResponse response = null;
- CloseableHttpClient httpClient = HttpClients.createDefault();
- RequestConfig requestConfig = RequestConfig.custom().
- setSocketTimeout(2000).setConnectTimeout(2000).build();
- httpPost.setConfig(requestConfig);
- httpPost.addHeader("Content-Type", "application/json");
- try {
- StringEntity requestEntity = new StringEntity(JSON.toJSONString(data), "utf-8");
- httpPost.setEntity(requestEntity);
-
- response = httpClient.execute(httpPost, new BasicHttpContext());
- if (response.getStatusLine().getStatusCode() != 200) {
- System.out.println("request url failed, http code=" + response.getStatusLine().getStatusCode()
- + ", url=" + url);
- return null;
- }
- HttpEntity entity = response.getEntity();
- if (entity != null) {
- String resultStr = EntityUtils.toString(entity, "utf-8");
- JSONObject result = JSON.parseObject(resultStr);
- if (result.getInteger("errcode") == 0) {
- result.remove("errcode");
- result.remove("errmsg");
- return result;
- } else {
- System.out.println("request url=" + url + ",return value=");
- System.out.println(resultStr);
- int errCode = result.getInteger("errcode");
- String errMsg = result.getString("errmsg");
- throw new OApiException(errCode, errMsg);
- }
- }
- } catch (IOException e) {
- System.out.println("request url=" + url + ", exception, msg=" + e.getMessage());
- e.printStackTrace();
- } finally {
- if (response != null) try {
- response.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- return null;
- }
-
-
- public static JSONObject uploadMedia(String url, File file) throws OApiException {
- HttpPost httpPost = new HttpPost(url);
- CloseableHttpResponse response = null;
- CloseableHttpClient httpClient = HttpClients.createDefault();
- RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(2000).setConnectTimeout(2000).build();
- httpPost.setConfig(requestConfig);
- HttpEntity requestEntity = MultipartEntityBuilder.create().addPart("media",
- new FileBody(file, ContentType.APPLICATION_OCTET_STREAM, file.getName())).build();
- httpPost.setEntity(requestEntity);
- try {
- response = httpClient.execute(httpPost, new BasicHttpContext());
- if (response.getStatusLine().getStatusCode() != 200) {
- System.out.println("request url failed, http code=" + response.getStatusLine().getStatusCode()
- + ", url=" + url);
- return null;
- }
- HttpEntity entity = response.getEntity();
- if (entity != null) {
- String resultStr = EntityUtils.toString(entity, "utf-8");
- JSONObject result = JSON.parseObject(resultStr);
- if (result.getInteger("errcode") == 0) {
- // 成功
- result.remove("errcode");
- result.remove("errmsg");
- return result;
- } else {
- System.out.println("request url=" + url + ",return value=");
- System.out.println(resultStr);
- int errCode = result.getInteger("errcode");
- String errMsg = result.getString("errmsg");
- throw new OApiException(errCode, errMsg);
- }
- }
- } catch (IOException e) {
- System.out.println("request url=" + url + ", exception, msg=" + e.getMessage());
- e.printStackTrace();
- } finally {
- if (response != null) try {
- response.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- return null;
- }
-
-
- public static JSONObject downloadMedia(String url, String fileDir) throws OApiException {
- HttpGet httpGet = new HttpGet(url);
- CloseableHttpResponse response = null;
- CloseableHttpClient httpClient = HttpClients.createDefault();
- RequestConfig requestConfig = RequestConfig.custom().setSocketTimeout(2000).setConnectTimeout(2000).build();
- httpGet.setConfig(requestConfig);
- try {
- HttpContext localContext = new BasicHttpContext();
- response = httpClient.execute(httpGet, localContext);
- RedirectLocations locations = (RedirectLocations) localContext.getAttribute(HttpClientContext.REDIRECT_LOCATIONS);
- if (locations != null) {
- URI downloadUrl = locations.getAll().get(0);
- String filename = downloadUrl.toURL().getFile();
- System.out.println("downloadUrl=" + downloadUrl);
- File downloadFile = new File(fileDir + File.separator + filename);
- FileUtils.writeByteArrayToFile(downloadFile, EntityUtils.toByteArray(response.getEntity()));
- JSONObject obj = new JSONObject();
- obj.put("downloadFilePath", downloadFile.getAbsolutePath());
- obj.put("httpcode", response.getStatusLine().getStatusCode());
-
-
-
- return obj;
- } else {
- if (response.getStatusLine().getStatusCode() != 200) {
- System.out.println("request url failed, http code=" + response.getStatusLine().getStatusCode()
- + ", url=" + url);
- return null;
- }
- HttpEntity entity = response.getEntity();
- if (entity != null) {
- String resultStr = EntityUtils.toString(entity, "utf-8");
- JSONObject result = JSON.parseObject(resultStr);
- if (result.getInteger("errcode") == 0) {
- // 成功
- result.remove("errcode");
- result.remove("errmsg");
- return result;
- } else {
- System.out.println("request url=" + url + ",return value=");
- System.out.println(resultStr);
- int errCode = result.getInteger("errcode");
- String errMsg = result.getString("errmsg");
- throw new OApiException(errCode, errMsg);
- }
- }
- }
- } catch (IOException e) {
- System.out.println("request url=" + url + ", exception, msg=" + e.getMessage());
- e.printStackTrace();
- } finally {
- if (response != null) try {
- response.close();
- } catch (IOException e) {
- e.printStackTrace();
- }
- }
- return null;
- }
- }
|