标签:hand exec 请求方式 nec 状态码 logger 重试 set 对象
@SuppressWarnings("deprecation")
public class HttpClientUtil {
private static Logger logger = LoggerFactory.getLogger(HttpClientUtil.class);
private static final String ContentEncoding = "UTF-8";
private static final int SocketTimeout = 5000;
/**
httpClient的get请求方式
* @return
* @throws Exception
*/
public static String doGet(String url) {
logger.info("get请求{}",url);
/*
* 使用 GetMethod 来访问一个 URL 对应的网页,实现步骤:
* 1:生成一个 HttpClinet 对象并设置相应的参数。
* 2:生成一个 GetMethod 对象并设置响应的参数。
* 3:用 HttpClinet 生成的对象来执行 GetMethod 生成的Get方法。
* 4:处理响应状态码。
* 5:若响应正常,处理 HTTP 响应内容。
* 6:释放连接。
*/
/* 1 生成 HttpClinet 对象并设置参数 */
HttpClient httpClient = new HttpClient();
// 设置 Http 连接超时为5秒
httpClient.getHttpConnectionManager().getParams().setConnectionTimeout(SocketTimeout);
/* 2 生成 GetMethod 对象并设置参数 */
GetMethod getMethod = new GetMethod(url);
// 设置 get 请求超时为 5 秒
getMethod.getParams().setParameter(HttpMethodParams.SO_TIMEOUT, SocketTimeout);
// 设置请求重试处理,用的是默认的重试处理:请求三次
getMethod.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, new DefaultHttpMethodRetryHandler());
String response = "";
/* 3 执行 HTTP GET 请求 */
try {
int statusCode = httpClient.executeMethod(getMethod);
logger.info("get请求{}",statusCode);
/* 4 判断访问的状态码 */
if (statusCode != HttpStatus.SC_OK&&statusCode != HttpStatus.SC_CREATED&&statusCode != HttpStatus.SC_NO_CONTENT) {
logger.error("请求出错: "+ getMethod.getStatusLine());
return response;
}
// 读取 HTTP 响应内容,这里简单打印网页内容
byte[] responseBody = getMethod.getResponseBody();// 读取为字节数组
response = new String(responseBody, ContentEncoding);
logger.info("----------response:" + response);
// 读取为 InputStream,在网页内容数据量大时候推荐使用
// InputStream response = getMethod.getResponseBodyAsStream();
} catch (HttpException e) {
// 发生致命的异常,可能是协议不对或者返回的内容有问题
logger.error("请检查输入的URL!");
e.printStackTrace();
} catch (IOException e) {
// 发生网络异常
logger.error("发生网络异常!");
e.printStackTrace();
} finally {
/* 6 .释放连接 */
getMethod.releaseConnection();
}
return response;
}
/**
* HttpClient PUT请求
* @author huang
* @date 2013-4-10
* @return
*/
public static String doPut(String uri,String jsonObj){
logger.info("put请求{},{}",uri,jsonObj);
String resStr = "";
HttpClient htpClient = new HttpClient();
PutMethod putMethod = new PutMethod(uri);
putMethod.addRequestHeader( "Content-Type","application/json" );
putMethod.getParams().setParameter( HttpMethodParams.HTTP_CONTENT_CHARSET, ContentEncoding );
putMethod.setRequestBody( jsonObj );
try{
int statusCode = htpClient.executeMethod( putMethod );
logger.info("put请求{}",statusCode);
if (statusCode != HttpStatus.SC_OK&&statusCode != HttpStatus.SC_CREATED&&statusCode != HttpStatus.SC_NO_CONTENT) {
logger.error("Method failed: "+putMethod.getStatusLine() );
return resStr;
}
byte[] responseBody = putMethod.getResponseBody();
resStr = new String(responseBody,ContentEncoding);
logger.info("response:" + resStr);
}catch(Exception e){
logger.error(" failed: " + e.getMessage());
e.printStackTrace();
}finally{
putMethod.releaseConnection();
}
return resStr;
}
/**
* post请求
* @param url
* @param jsonObj
* @return
*/
@SuppressWarnings({ "resource" })
public static String doPost(String url,String jsonObj){
logger.info("post请求{},{}",url,jsonObj);
DefaultHttpClient client = new DefaultHttpClient();
HttpPost post = new HttpPost(url);
post.setHeader("Content-Type", "application/json; charset=UTF-8");
String response = "";
try {
StringEntity stringEntity = new StringEntity( jsonObj,"UTF-8");
stringEntity.setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE, "application/json"));
post.setEntity(stringEntity);
HttpResponse res = client.execute(post);
int statusCode=res.getStatusLine().getStatusCode();
logger.info("post请求",statusCode);
if (statusCode != HttpStatus.SC_OK&&statusCode != HttpStatus.SC_CREATED&&statusCode != HttpStatus.SC_NO_CONTENT) {
logger.error("Method failed: "+res.getStatusLine() );
return response;
}
response = EntityUtils.toString(res.getEntity());// 返回json格式:
logger.info("----------response:" + response);
} catch (Exception e) {
logger.error(" failed: " + e.getMessage());
e.printStackTrace();
}
return response;
}
public static String doDelete(String uri) {
logger.info("delete请求",uri);
String data= "";
HttpClient httpClient= new HttpClient();
httpClient.getParams().setParameter(HttpMethodParams.HTTP_CONTENT_CHARSET, ContentEncoding);
DeleteMethod method = null;
try{
method= new DeleteMethod();
method.setURI(new URI(uri,false));
method.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, new DefaultHttpMethodRetryHandler());
method.getParams().setParameter(HttpMethodParams.SO_TIMEOUT, SocketTimeout);
int statusCode = httpClient.executeMethod(method);
logger.info("delete请求",statusCode);
if (statusCode != HttpStatus.SC_OK&&statusCode != HttpStatus.SC_CREATED&&statusCode != HttpStatus.SC_NO_CONTENT) {
logger.error("Method failed: " + method.getStatusLine());
return data;
}
data= new String(method.getResponseBody(),ContentEncoding);
logger.info("response:" + data);
}catch(HttpException e){
e.printStackTrace();
logger.error("Please check your provided http address!");
}catch(IOException e){
e.printStackTrace();
logger.error(e.getMessage());
}catch(Exception e){
e.printStackTrace();
logger.error(e.getMessage());
}finally{
if(method!=null)
method.releaseConnection();
}
return data;
}
public static void main(String args[]) {
}
}
httpclient 封装 http(get put post delete)请求
标签:hand exec 请求方式 nec 状态码 logger 重试 set 对象
原文地址:https://www.cnblogs.com/aizj/p/9323101.html