Apache HttpClient - 分段上传

  • 简述

    使用 HttpClient,我们可以进行分段上传,即我们可以在 较小的部分。在本章中,我们通过上传一个简单的文本文件来演示 HTTP 客户端的分段上传。
    一般来说,任何分段上传都包含三个部分。
    • 开始上传
    • 上传对象部分
    • 完成分段上传
    对于使用 HttpClient 的分段上传,我们需要遵循以下步骤 -
    • 创建一个多部分构建器。
    • 向其中添加所需的部分。
    • 完成构建并获得一个多部分的HttpEntity。
    • 通过设置上述多部分实体构建请求。
    • 执行请求。
    以下是使用 HttpClient 库上传多部分实体的步骤。
  • 第 1 步 - 创建一个 HttpClient 对象

    HttpClients类的createDefault()方法返回一个类的对象CloseableHttpClient,它是 HttpClient 接口的基本实现。使用此方法,创建一个 HttpClient 对象 -
    
    //创建CloseableHttpClient对象
    CloseableHttpClient httpclient = HttpClients.createDefault();
    
  • 第 2 步 - 创建 FileBody 对象

    FileBody 类表示由文件支持的二进制正文部分。通过传递一个 File 对象和一个表示内容类型的 ContentType 对象来实例化这个类。
    
    //创建一个文件对象
    File file = new File("sample.txt");
    //Creating the FileBody object
    FileBody filebody = new FileBody(file, ContentType.DEFAULT_BINARY);
    
  • 第 3 步 - 创建 MultipartEntityBuilder

    MultipartEntityBuilder 类用于构建多部分 HttpEntity 对象。使用 create() 方法(同一个类)创建它的对象。
    
    //创建MultipartEntityBuilder
    MultipartEntityBuilder entitybuilder = MultipartEntityBuilder.create();
    
  • 第 4 步 - 设置模式

    MultipartEntityBuilder 具有三种模式:STRICT、RFC6532 和 BROWSER_COMPATIBLE。使用 setMode() 方法将其设置为所需的模式。
    
    //设置模式
    entitybuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
    
  • 第 5 步 - 添加各种所需的部分

    使用 addTextBody()、addPart() 和 addBinaryBody() 方法,您可以添加简单的文本、文件、流和其他对象到 MultipartBuilder。使用这些方法添加所需的内容。
    
    //添加文字
    entitybuilder.addTextBody("sample_text", "这是我们文件的文本部分");
    //添加一个文件
    entitybuilder.addBinaryBody("image", new File("logo.png"));
    
  • 第 6 步 - 构建单个实体

    您可以使用 MultipartEntityBuilder 类的 build() 方法将所有这些部分构建为单个实体。使用此方法,将所有部分构建为一个 HttpEntity
    
    //构建使用零件制作单个实体
    HttpEntity mutiPartHttpEntity = entityBuilder.build();
    
  • 第 7 步 - 创建 RequestBuilder 对象

    RequestBuilder 类通过添加参数来构建请求。如果请求是 PUT 或 POST 类型,它会将参数作为 URL 编码实体添加到请求中。
    使用 post() 方法创建一个 RequestBuilder 对象(POST 类型)。并通过 Uri 您希望将其作为参数发送到的请求。
    
    //构建post请求对象
    RequestBuilder reqbuilder = RequestBuilder.post("http://httpbin.org/post");
    
  • 第 8 步-将实体对象设置为RequestBuilder

    使用 RequestBuilder 类的 setEntity() 方法将上面创建的多部分实体设置为 RequestBuilder。
    
    //设置实体对象到RequestBuilder
    reqbuilder.setEntity(mutiPartHttpEntity);
    
  • 第 9 步 - 构建 HttpUriRequest

    使用 RequestBuilder< 的 build() 方法构建一个 HttpUriRequest 对象。
    
    //构建请求
    HttpUriRequest multipartRequest = reqbuilder.build();
    
  • 第 10 步 - 执行请求

    使用execute()方法,执行上一步构建的请求(将请求作为参数绕过该方法)。
    
    //执行请求
    HttpResponse httpresponse = httpclient.execute(multipartRequest);
    
  • 示例

    以下示例演示了如何使用 HttpClient 库发送多部分请求。在此示例中,我们尝试发送由文件支持的多部分请求。
    
    import org.apache.http.HttpEntity;
    import org.apache.http.HttpResponse;
    import org.apache.http.client.methods.HttpUriRequest;
    import org.apache.http.client.methods.RequestBuilder;
    import org.apache.http.entity.ContentType;
    import org.apache.http.entity.mime.HttpMultipartMode;
    import org.apache.http.entity.mime.MultipartEntityBuilder;
    import org.apache.http.entity.mime.content.FileBody;
    import org.apache.http.impl.client.CloseableHttpClient;
    import org.apache.http.impl.client.HttpClients;
    import org.apache.http.util.EntityUtils;
    import java.io.File;
    import java.io.IOException;
    import java.net.URISyntaxException;
    public class MultipartUploadExample {
     
       public static void main(String args[]) throws Exception{
          //Creating CloseableHttpClient object
          CloseableHttpClient httpclient = HttpClients.createDefault();
     
          //Creating a file object
          File file = new File("sample.txt");
          //Creating the FileBody object
          FileBody filebody = new FileBody(file, ContentType.DEFAULT_BINARY);
          //Creating the MultipartEntityBuilder
          MultipartEntityBuilder entitybuilder = MultipartEntityBuilder.create();
          //Setting the mode
          entitybuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
          //Adding text
          entitybuilder.addTextBody("sample_text", "This is the text part of our file");
          //Adding a file
          entitybuilder.addBinaryBody("image", new File("logo.png"));
          //Building a single entity using the parts
          HttpEntity mutiPartHttpEntity = entitybuilder.build();
          //Building the RequestBuilder request object
          RequestBuilder reqbuilder = RequestBuilder.post("http://httpbin.org/post");
          //Set the entity object to the RequestBuilder
          reqbuilder.setEntity(mutiPartHttpEntity);
          //Building the request
          HttpUriRequest multipartRequest = reqbuilder.build();
          //Executing the request
          HttpResponse httpresponse = httpclient.execute(multipartRequest);
          //Printing the status and the contents of the response
          System.out.println(EntityUtils.toString(httpresponse.getEntity()));
          System.out.println(httpresponse.getStatusLine());
       }
    } 
    
  • 输出

    在执行时,上面的程序生成以下输出 -
    
    {
       "args": {},
       "data": "",
       "files": {
          "image": "data:application/octets66PohrH3IWNk1FzpohfdXPIfv9X3490FGcuXsHn9X0piCwomF/xdgADZ9GsfSyvLYAAAAAE
          lFTkSuQmCC"
       },
       "form": {
          "sample_text": "This is the text part of our file"
       },
       "headers": {
          "Accept-Encoding": "gzip,deflate",
          "Connection": "close",
          "Content-Length": "11104", 
          "Content-Type": "multipart/form-data;
          boundary=UFJbPHT7mTwpVq70LpZgCi5I2nvxd1g-I8Rt",
          "Host": "httpbin.org",
          "User-Agent": "Apache-HttpClient/4.5.6 (Java/1.8.0_91)"
       },
       "json": null,
       "origin": "117.216.245.180",
       "url": "http://httpbin.org/post"
    }
    HTTP/1.1 200 OK