zoukankan      html  css  js  c++  java
  • HttpClient的使用

    HttpClient的使用

    一、简介

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

    二、特性

    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. 释放连接。无论执行方法是否成功,都必须释放连接

    Get请求使用方法

        public void get(View view) {
    new Thread() {
    public void run() {
    try {
    // 创建请求发送对象HttpClient
    HttpClient client = new DefaultHttpClient();
    // 创建get
    String url = "http://www.baidu.com";
    HttpGet get = new HttpGet(url);
    // 服务端返回数据
    HttpResponse response = client.execute(get);// 发送 没有封装线程的对象
    // 就不需要回调
    InputStream input = response.getEntity().getContent();
    byte[] data = StreamUtils.readInputStream(input);
    String result = new String(data, "utf-8");
    Log.i("wzx", result);
    input.close();
    } catch (Exception e) {
    e.printStackTrace();
    }
    };
    }.start();
    }

    Psot()

    public void post(View view) {

    new Thread() {
    public void run() {
    try {
    // 创建请求发送对象HttpClient
    HttpClient client = new DefaultHttpClient();
    // 创建post
    String url = "http://192.168.32.10:8080/web/LoginServlet";
    HttpPost post = new HttpPost(url);

    // 变量 NameValuePair:Map.Entry
    NameValuePair username = new BasicNameValuePair("username", "中国ujj");
    NameValuePair passowrd = new BasicNameValuePair("password", "中国ujj");

    List<NameValuePair> params = new ArrayList<NameValuePair>();
    params.add(username);
    params.add(passowrd);

    UrlEncodedFormEntity form = new UrlEncodedFormEntity(params, "utf-8");
    post.setEntity(form);// 添加表单到请求里,带到服务端
    // 服务端返回数据
    HttpResponse response = client.execute(post);// 发送 没有封装线程的对象
    InputStream input = response.getEntity().getContent();
    byte[] data = StreamUtils.readInputStream(input);
    String result = new String(data, "utf-8");
    Log.i("wzx", result);
    input.close();
    } catch (Exception e) {
    e.printStackTrace();
    }
    };
    }.start();
    }
  • 相关阅读:
    cassandra复制到一个新机器编译失败的问题
    cassandra在服务端像leveldb一样进行插入初试成功
    git push不成功 insufficient permission for adding an object to repository database
    fuse进级
    fuse入门
    cassandra的写过程
    cassandra-执行请求入口函数
    cassandra-replication_factor 和 consistency level
    根据金额大小升序排序
    PL/SQL Developer连接本地Oracle 11g 64位数据库(转)
  • 原文地址:https://www.cnblogs.com/ganwei/p/4888642.html
Copyright © 2011-2022 走看看