java httppost jar_java使用httpclient发送post请求示例

package org.ssi.util;

import java.io.IOException;

import java.util.ArrayList;

import java.util.List;

import net.sf.json.JSONArray;

import org.apache.commons.lang.exception.ExceptionUtils;

import org.apache.commons.logging.Log;

import org.apache.commons.logging.LogFactory;

import org.apache.http.HttpResponse;

import org.apache.http.HttpStatus;

import org.apache.http.NameValuePair;

import org.apache.http.client.HttpClient;

import org.apache.http.client.entity.UrlEncodedFormEntity;

import org.apache.http.client.methods.HttpPost;

import org.apache.http.impl.client.DefaultHttpClient;

import org.apache.http.message.BasicNameValuePair;

import org.apache.http.protocol.HTTP;

import org.apache.http.util.EntityUtils;

public class APIHttpClient {

//接口地址

private String apiURL = "";

private Log logger = LogFactory.getLog(this.getClass());

private static final String pattern = "yyyy-MM-dd HH:mm:ss:SSS";

private HttpClient httpClient = null;

private HttpPost method = null;

private long startTime = 0L;

private long endTime = 0L;

private int status = 0;

/**

* 接口地址

* @param url

*/

public APIHttpClient(String url){

if(url != null)

{

this.apiURL = url;

}

if(apiURL != null)

{

httpClient = new DefaultHttpClient();

method = new HttpPost(apiURL);

}

}

/**

* 调用 API

* @param parameters

* @return

*/

public String post(String parameters)

{

String body = null;

logger.info("parameters:" + parameters);

if(method != null & parameters != null  && !"".equals(parameters.trim()))

{

JSONArray jsonObject = JSONArray.fromObject(parameters);

logger.info("json:" + jsonObject.toString());

try{

List params=new ArrayList();

//建立一个NameValuePair数组,用于存储欲传送的参数

params.add(new BasicNameValuePair("data",parameters));

//添加参数

method.setEntity(new UrlEncodedFormEntity(params,HTTP.UTF_8));

startTime = System.currentTimeMillis();

//设置编码

HttpResponse response=httpClient.execute(method);

endTime = System.currentTimeMillis();

int statusCode = response.getStatusLine().getStatusCode();

logger.info("statusCode:" + statusCode);

logger.info("调用API 花费时间(单位:毫秒):" + (endTime - startTime));

if(statusCode != HttpStatus.SC_OK){

logger.error("Method failed:"+response.getStatusLine());

status = 1;

}

//Read the response body

body=EntityUtils.toString(response.getEntity());

}catch(IOException e){

//发生网络异常

logger.error("exception occurred!\n"+ExceptionUtils.getFullStackTrace(e));

//网络错误

status = 3;

}

finally{

logger.info("调用接口状态:" + status);

}

}

return body;

}

/**

* 0.成功 1.执行方法失败 2.协议错误 3.网络错误

* @return the status

*/

public int getStatus() {

return status;

}

/**

* @param status the status to set

*/

public void setStatus(int status) {

this.status = status;

}

/**

* @return the startTime

*/

public long getStartTime() {

return startTime;

}

/**

* @return the endTime

*/

public long getEndTime() {

return endTime;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值