复制代码代码如下:
пакет org.ssi.util;
импортировать java.io.IOException;
импортировать java.util.ArrayList;
импортировать java.util.List;
импортировать net.sf.json.JSONArray;
импортировать org.apache.commons.lang.Exception.ExceptionUtils;
импортировать org.apache.commons.logging.Log;
импортировать org.apache.commons.logging.LogFactory;
импортировать org.apache.http.HttpResponse;
импортировать org.apache.http.HttpStatus;
импортировать org.apache.http.NameValuePair;
импортировать org.apache.http.client.HttpClient;
импортировать org.apache.http.client.entity.UrlEncodedFormEntity;
импортировать org.apache.http.client.methods.HttpPost;
импортировать org.apache.http.impl.client.DefaultHttpClient;
импортировать org.apache.http.message.BasicNameValuePair;
импортировать org.apache.http.protocol.HTTP;
импортировать org.apache.http.util.EntityUtils;
публичный класс APIHttpClient {
//接口地址
частная строка apiURL = "";
частный регистратор журнала = LogFactory.getLog(this.getClass());
частный статический окончательный шаблон String = "гггг-ММ-дд ЧЧ: мм:сс:ССС";
частный HttpClient httpClient = null;
частный метод HttpPost = null;
частный длинный startTime = 0L;
частный длинный endTime = 0L;
частный статус int = 0;
/**
* 接口地址
* URL-адрес @param
*/
public APIHttpClient (строковый URL) {
если (URL! = ноль)
{
this.apiURL = URL;
}
если (apiURL! = ноль)
{
httpClient = новый DefaultHttpClient();
метод = новый HttpPost (apiURL);
}
}
/**
* Общий API
* параметры @param
* @возвращаться
*/
общедоступное сообщение String (параметры String)
{
Тело строки = ноль;
logger.info("Параметры:" + параметры);
if(метод != null & параметры != null && !"".equals(parameters.trim()))
{
JSONArray jsonObject = JSONArray.fromObject(параметры);
logger.info("json:" + jsonObject.toString());
пытаться{
List<NameValuePair> params=new ArrayList<NameValuePair>();
//建立一个NameValuePair数组,用于存储欲传送的参数
params.add(new BasicNameValuePair("данные",параметры));
// 添加参数
метод.setEntity(новый UrlEncodedFormEntity(params,HTTP.UTF_8));
startTime = System.currentTimeMillis();
// 设置编码
Ответ HttpResponse = httpClient.execute (метод);
endTime = System.currentTimeMillis();
int statusCode = response.getStatusLine().getStatusCode();
logger.info("statusCode:" + statusCode);
logger.info("调用API 花费时间(单位:毫秒):" + (endTime - startTime));
если(statusCode!= HttpStatus.SC_OK){
logger.error("Метод не выполнен:"+response.getStatusLine());
статус = 1;
}
//Читаем тело ответа
body = EntityUtils.toString(response.getEntity());
}catch(IOException e){
// 发生网络异常
logger.error("Произошло исключение!/n"+ExceptionUtils.getFullStackTrace(e));
//网络错误
статус = 3;
}
окончательно{
logger.info("Стартовый режим:" + status);
}
}
вернуть тело;
}
/**
* 0.成功 1.执行方法失败 2.协议错误 3.网络错误
* @вернуть статус
*/
общественный ИНТ getStatus () {
статус возврата;
}
/**
* @param status статус, который нужно установить
*/
общественный недействительный setStatus (int status) {
this.status = статус;
}
/**
* @return время начала
*/
общественный длинный getStartTime() {
вернуть время начала;
}
/**
* @return конечное время
*/
общественный длинный getEndTime() {
вернуть конечное время;
}
}