HttpClient使用讲解

HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会更加深入。

一、简介

HttpClient是Apache Jakarta Common下的子项目,用来提供高效的、最新的、功能丰富的支持HTTP协议的客户端编程工具包,并且它支持HTTP协议最新的版本和建议。HttpClient已经应用在很多的项目中,比如Apache Jakarta上很著名的另外两个开源项目Cactus和HTMLUnit都使用了HttpClient。

下载地址: http://hc.apache.org/downloads.cgi

二、特性

1. 基于标准、纯净的java语言。实现了Http1.0和Http1.1

2. 以可扩展的面向对象的结构实现了Http全部的方法(GET, POST, PUT, DELETE, HEAD, OPTIONS, and TRACE)。

3. 支持HTTPS协议。

4. 通过Http代理建立透明的连接。

5. 利用CONNECT方法通过Http代理建立隧道的https连接。

6. Basic, Digest, NTLMv1, NTLMv2, NTLM2 Session, SNPNEGO/Kerberos认证方案。

7. 插件式的自定义认证方案。

8. 便携可靠的套接字工厂使它更容易的使用第三方解决方案。

9. 连接管理器支持多线程应用。支持设置最大连接数,同时支持设置每个主机的最大连接数,发现并关闭过期的连接。

10. 自动处理Set-Cookie中的Cookie。

11. 插件式的自定义Cookie策略。

12. Request的输出流可以避免流中内容直接缓冲socket服务器。

13. Response的输入流可以有效的从socket服务器直接读取相应内容。

14. 在http1.0和http1.1中利用KeepAlive保持持久连接。

15. 直接获取服务器发送的response code和 headers。

16. 设置连接超时的能力。

17. 实验性的支持http1.1 response caching。

18. 源代码基于Apache License 可免费获取。

三、使用方法

使用HttpClient发送请求、接收响应很简单,一般需要如下几步即可。

1. 创建HttpClient对象。

2. 创建请求方法的实例,并指定请求URL。如果需要发送GET请求,创建HttpGet对象;如果需要发送POST请求,创建HttpPost对象。

3. 如果需要发送请求参数,可调用HttpGet、HttpPost共同的setParams(HetpParams params)方法来添加请求参数;对于HttpPost对象而言,也可调用setEntity(HttpEntity entity)方法来设置请求参数。

4. 调用HttpClient对象的execute(HttpUriRequest request)发送请求,该方法返回一个HttpResponse。

5. 调用HttpResponse的getAllHeaders()、getHeaders(String name)等方法可获取服务器的响应头;调用HttpResponse的getEntity()方法可获取HttpEntity对象,该对象包装了服务器的响应内容。程序可通过该对象获取服务器的响应内容。

6. 释放连接。无论执行方法是否成功,都必须释放连接。此时必须使用CloseableHttpClient,才能关闭链接!!!

四、示例

 
public class Demo{
    public static void main(String[] args) throws Exception {
        //1、创建client对象
        CloseableHttpClient client = HttpClients.createDefault();
        try {
	    //2、设置请求方法的路径
            String url = "http://www.baidu.com";			
	    HttpPost post = new HttpPost(url);
	    //3、设置请求参数
	    JSONObject requestObj = "{key:'httpclient'}";				
	    StringEntity entity = new StringEntity(requestObj.toString(),"UTF-8");
	    post.setEntity(entity);
	    //4、执行请求				
	    HttpResponse response = client.execute(post);		
	    //5、解析响应,本示例响应结果格式为json
	    String reqResult = EntityUtils.toString(response.getEntity());
	    JSONObject json = JSON.parseObject(reqResult);
	    String status = json.getString("status");
	    if(status.equals("success")){
		System.out.println("请求成功!!!");
	    }
        } finally {
	   //6、关闭链接,释放资源
 
 
 
 
           if(client!=null){
		try {
		     client.close();
		} catch (IOException e) {
		     e.printStackTrace();
		}
	   }
        }
    }
}

.NET框架中的HttpClient是一个用于处理HTTP请求和响应的高效、轻量级库。它提供了一种简单的方式来发送GET、POST、PUT等HTTP方法,并支持异步操作,非常适合网络通信场景。 **HttpClient的基本使用步骤:** 1. **创建实例:** ```csharp using HttpClient client = new HttpClient(); ``` 2. **设置基本配置(可选):** - 设置超时时间: ```csharp client.Timeout = TimeSpan.FromSeconds(5); ``` - 配置默认的代理服务器: ```csharp client.DefaultRequestHeaders.Proxy = WebProxy.Parse("http://your-proxy-server.com"); ``` 3. **发送请求:** - GET请求: ```csharp HttpResponseMessage response = await client.GetAsync("https://api.example.com/data"); ``` - POST请求: ```csharp var content = new StringContent("{'key': 'value'}", Encoding.UTF8, "application/json"); HttpResponseMessage response = await client.PostAsync("https://api.example.com/post", content); ``` 4. **检查响应状态并获取数据:** ```csharp if (response.IsSuccessStatusCode) { string responseBody = await response.Content.ReadAsStringAsync(); Console.WriteLine(responseBody); } else { // 处理错误情况 } ``` **示例:** ```csharp using System; using System.Net.Http; class Program { static async Task Main(string[] args) { try { using (HttpClient client = new HttpClient()) { HttpResponseMessage response = await client.GetAsync("https://jsonplaceholder.typicode.com/todos/1"); if (response.IsSuccessStatusCode) { string json = await response.Content.ReadAsStringAsync(); dynamic data = Newtonsoft.Json.JsonConvert.DeserializeObject(json); Console.WriteLine($"Todo ID: {data.id}, Title: {data.title}"); } else { Console.WriteLine($"Error: {response.StatusCode}"); } } } catch (Exception ex) { Console.WriteLine($"An error occurred: {ex.Message}"); } } } ``` 在这个例子中,我们向`jsonplaceholder.typicode.com`的一个API端点发送了一个GET请求,获取第一条todo信息,并将结果解析成动态JSON对象。 **相关问题--:** 1. HttpClient如何处理HTTP头? 2. 如何处理HttpClient的异常? 3. HttpClient是否线程安全?如果需要跨线程使用,应该如何处理?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值