import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import javax.net.ssl.SSLContext;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import org.apache.commons.collections.MapUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.conn.ClientConnectionManager;
import org.apache.http.conn.scheme.Scheme;
import org.apache.http.conn.scheme.SchemeRegistry;
import org.apache.http.conn.ssl.SSLSocketFactory;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.common.base.Joiner;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
public class HttpUtil {
private static final Logger LOG = LoggerFactory.getLogger(HttpUtil.class);
public static DefaultHttpClient getHttpsClient()
{
try {
SSLContext ctx = SSLContext.getInstance("TLS");
X509TrustManager tm = new X509TrustManager() {
@Override
public void checkClientTrusted(
java.security.cert.X509Certificate[] chain,
String authType)
throws java.security.cert.CertificateException {
}
@Override
public void checkServerTrusted(
java.security.cert.X509Certificate[] chain,
String authType)
throws java.security.cert.CertificateException {
}
@Override
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return null;
}
};
DefaultHttpClient client = new DefaultHttpClient();
ctx.init(null, new TrustManager[] { tm }, null);
SSLSocketFactory ssf = new SSLSocketFactory(ctx);
ClientConnectionManager ccm = client.getConnectionManager();
SchemeRegistry sr = ccm.getSchemeRegistry();
//设置要使用的端口,默认是443
sr.register(new Scheme("https", 443, ssf));
return client;
} catch (Exception ex) {
LOG.error("", ex);
return null;
}
}
/**
*
* @param url
* @param params
* @return
* @author asflex
* @date 2014-3-28下午7:24:02
* @modify 2014-3-28下午7:24:02
*/
public static String post(String url, Map<String, String> params) {
DefaultHttpClient httpClient = getHttpsClient();
HttpPost post = new HttpPost(url);
HttpEntity entity = map2UrlEncodedFormEntity(params);
if(entity != null) {
post.setEntity(entity);
}
LOG.info("http post---{}", getUrlRequestInfo(url, params));
HttpResponse response;
try {
response = httpClient.execute(post);
String result = EntityUtils.toString(response.getEntity());
return result;
} catch (ClientProtocolException e) {
LOG.error("", e);
} catch (IOException e) {
LOG.error("", e);
} finally {
httpClient.getConnectionManager().shutdown();
}
return null;
}
/**
* 生成post请求时的记录
* @param url
* @param params
* @return
* @author asflex
* @date 2014-3-28下午7:23:33
* @modify 2014-3-28下午7:23:33
*/
public static String getUrlRequestInfo(String url, Map<String, String> params) {
StringBuilder paramStr = new StringBuilder();
if(MapUtils.isNotEmpty(params)) {
Iterator<Entry<String, String>> iterator = params.entrySet().iterator();
Joiner.on("&").appendTo(paramStr, iterator);
}
return String.format("curl -d '%s' '%s'", StringUtils.trimToEmpty(paramStr.toString()), StringUtils.trimToEmpty(url));
}
/**
* 参数转换
* @param params
* @return
* @author asflex
* @date 2014-3-28下午7:23:05
* @modify 2014-3-28下午7:23:05
*/
public static HttpEntity map2UrlEncodedFormEntity(Map<String, String> params) {
if(MapUtils.isNotEmpty(params)) {
Iterator<Entry<String, String>> iterator = params.entrySet().iterator();
List<NameValuePair> nvps = Lists.newArrayList();
while(iterator.hasNext()) {
Entry<String, String> entry = iterator.next();
nvps.add(new BasicNameValuePair(StringUtils.trimToEmpty(entry.getKey()), StringUtils.trimToEmpty(entry.getValue())));
}
try {
return new UrlEncodedFormEntity(nvps);
} catch (UnsupportedEncodingException e) {
LOG.error("", e);
}
}
return null;
}
public static void main(String[] args) {
Map<String, String> params = Maps.newHashMapWithExpectedSize(8);
params.put("username", "fred5");
params.put("password", "1111");
params.put("vcode", "");
System.out.println(getUrlRequestInfo("", params));
System.out.println(post("https://www.baidu.com/webApi/logins.jsp", params));
}
}
分享到:
相关推荐
不会的可以在评论区留言哈,这是我自己做项目用到的。所以绝对可用!同时共享出来给到大家
在这个"HttpClient发起HTTPs请求.rar"压缩包中,我们主要关注的是如何利用HttpClient处理HTTPS协议的GET和POST请求,以及如何处理返回的JSON数据。这里,我们将详细讨论相关知识点。 首先,HTTPS是一种基于SSL/TLS...
- 在ESP8266上实现HTTPS请求,需要使用支持SSL/TLS的库,如Arduino的`ESP8266HTTPClient`库。 - `ESP8266HTTPClient`库提供了一个API,允许开发者轻松地发起GET、POST等HTTP请求,并处理响应。 3. **使用ESP8266...
"JAVA利用HttpClient进行POST请求(HTTPS)" JAVA HttpClient是Apache软件基金会提供的一个开源实现HTTP客户端的Java库,能够帮助开发者轻松地与HTTP服务器进行交互。在实际项目中,我们经常需要使用HttpClient来发送...
描述中提到的链接指向了一个ITEYE博客文章,虽然内容没有给出,但通常这类文章会包含如何配置和使用HttpClient来发送HTTPS请求的具体步骤。在实际操作中,我们可能需要关注以下几点: 1. **导入依赖**:文件列表中...
使用 HTTP Client 请求 HTTPS 的 API 时出现 The certificate cannot be verified up to a trusted certification authority 异常,并且证书已经传入。 下面就是问题代码: public class Program { public static...
总的来说,使用Java的HttpClient进行HTTPS接口调用涉及到配置SSL上下文、初始化HttpClient、创建请求对象以及处理响应。了解这些知识点对于开发安全的、能够与HTTPS服务进行通信的Java应用程序至关重要。通过实践和...
使用HttpClient4.5实现https请求忽略SSL证书验证工具类
除此之外,我们对请求添加签名的校验,key设置为X-Sign 接口定义 /// /// 获取时间戳(毫秒). /// /// <param name=dateTime></param> /// <returns></returns> [HttpPost] [AllowAnonymous]
HttpClient是Apache基金会开发的一个Java库,用于执行HTTP和HTTPS请求。在实际的IT工作中,HttpClient是一个非常重要的工具,尤其在需要进行HTTP通信或者自动化测试时。这篇博客“HttpClient Https实战”很可能详细...
首先,需要引入相关的Java包,包括java.io、java.net、javax.net.ssl等,并且需要使用Apache Commons HttpClient来处理Http和Https请求。 下面是HttpsUtil类的实现代码: ```java public class HttpsUtil { ...
在IT行业中,HttpClient是一个常用的Java库,用于执行HTTP和HTTPS请求。这个实例主要涉及如何配置HttpClient来忽略SSL(Secure Socket Layer)验证,这对于在开发和测试环境中处理自签名证书或未认证的服务器非常...
该工具类使用httpclient进行http or https请求,包括requestbody格式和form表单格式,另外含文件服务器中转上传方法,几乎支持所有常用接口调用,内含详细注释和说明文件,含jar包,及maven方式引用,拿过去直接用吧
本篇文章将详细介绍如何使用Java的HttpClient实现异步请求资源。 首先,让我们了解什么是异步请求。在同步请求中,调用一个API或发送一个HTTP请求后,程序会等待响应返回,然后继续执行后续代码。而异步请求则不同...
综上所述,HttpClientUtil工具类在IT应用中扮演着关键角色,简化了HTTP和HTTPS请求的实现,特别是发送文件这样的复杂操作。通过封装HttpClient的核心功能,开发者可以更加专注于业务逻辑,而不必关心底层网络通信的...
注意,执行完请求后需要关闭响应和HttpClient以释放资源。 对于POST请求,你需要创建一个HttpPost对象,并设置请求体: ```java HttpPost httpPost = new HttpPost("http://example.com"); List<NameValuePair> ...
在Java Web开发中,HTTPClient库是一个非常强大的工具,它允许开发者执行HTTP和HTTPS请求,进行数据交互。本文将深入探讨如何使用HTTPClient库来发送HTTPS请求,以及涉及到的证书管理相关知识。 首先,理解HTTPS...
在处理HTTPS请求时可能会遇到各种异常情况,比如证书验证失败等。为此,可以定义一个自定义异常类,例如`AuthSSLInitializationError`,用于捕获此类错误: ```java public class AuthSSLInitializationError ...
在C#中,我们可以使用`System.Net.Http`命名空间中的`HttpClient`类来发送HTTP/HTTPS请求。`HttpClient`提供了发送GET和POST请求的方法,如`GetAsync`和`PostAsync`。 4. **代码示例**: - `Program.cs`文件中...
在HTTPS通信中,`httpclient`库可以处理SSL/TLS握手、证书验证等复杂过程,使得应用程序可以简单地发送安全的HTTP请求。`httpclient`库也支持各种HTTP方法(如GET、POST)、重试策略、连接池管理等,极大地增强了...