复制代码代码如下:
pacoteorg.ssi.util;
importar java.io.IOException;
importar java.util.ArrayList;
importar java.util.List;
importar net.sf.json.JSONArray;
importar org.apache.commons.lang.exception.ExceptionUtils;
importar org.apache.commons.logging.Log;
importar org.apache.commons.logging.LogFactory;
importar org.apache.http.HttpResponse;
importar org.apache.http.HttpStatus;
importar org.apache.http.NameValuePair;
importar org.apache.http.client.HttpClient;
importar org.apache.http.client.entity.UrlEncodedFormEntity;
importar org.apache.http.client.methods.HttpPost;
importar org.apache.http.impl.client.DefaultHttpClient;
importar org.apache.http.message.BasicNameValuePair;
importar org.apache.http.protocol.HTTP;
importar org.apache.http.util.EntityUtils;
classe pública APIHttpClient {
//接口地址
String privada apiURL = "";
Registrador de log privado = LogFactory.getLog(this.getClass());
padrão de string final estático privado = "yyyy-MM-dd HH:mm:ss:SSS";
private HttpClient httpClient = null;
método HttpPost privado = null;
startTime longo privado = 0L;
endTime longo privado = 0L;
status interno privado = 0;
/**
* 接口地址
*@paramurl
*/
public APIHttpClient(Stringurl){
if(url! = nulo)
{
this.apiURL = url;
}
if (apiURL! = nulo)
{
httpClient = new DefaultHttpClient();
método = novo HttpPost(apiURL);
}
}
/**
* API da API
* @param parâmetros
* @retornar
*/
postagem de string pública (parâmetros de string)
{
Corpo da string = nulo;
logger.info("parâmetros:" + parâmetros);
if (método! = null & parâmetros! = null &&!"".equals(parameters.trim()))
{
JSONArray jsonObject = JSONArray.fromObject(parâmetros);
logger.info("json:" + jsonObject.toString());
tentar{
List<NomeValuePair> params=new ArrayList<NomeValuePair>();
//建立一个NameValuePair数组,用于存储欲传送的参数
params.add(new BasicNameValuePair("dados",parâmetros));
//添加参数
método.setEntity(novo UrlEncodedFormEntity(params,HTTP.UTF_8));
startTime = System.currentTimeMillis();
//设置编码
Resposta HttpResponse=httpClient.execute(método);
endTime = System.currentTimeMillis();
int statusCode = resposta.getStatusLine().getStatusCode();
logger.info("statusCode:" + statusCode);
logger.info("调用API 花费时间(单位:毫秒):" + (endTime - startTime));
if(statusCode != HttpStatus.SC_OK){
logger.error("Método falhou:"+response.getStatusLine());
estado = 1;
}
//Lê o corpo da resposta
body=EntityUtils.toString(response.getEntity());
}catch(IOException e){
//发生网络异常
logger.error("exceção ocorreu!/n"+ExceptionUtils.getFullStackTrace(e));
//网络错误
estado = 3;
}
finalmente{
logger.info("调用接口状态:" + status);
}
}
corpo de retorno;
}
/**
* 0.成功 1.执行方法失败 2.协议错误 3.网络错误
* @return o status
*/
public int getStatus() {
status de retorno;
}
/**
* @param status o status a ser definido
*/
public void setStatus(int status) {
este.status = status;
}
/**
* @return o startTime
*/
público longo getStartTime() {
retornar horário de início;
}
/**
* @return o fimHora
*/
público longo getEndTime() {
retornar fimHora;
}
}