【Java技术指南】「Unirest编程专题」一起认识一下一个“灰常”优秀的Http工具,让Http开发变得如此简单

简介: Unirest-Java是一个轻量级的HTTP客户端库,它提供了简单易用的API,可以帮助Java开发人员快速地发送HTTP请求和处理响应。在本文中,我们将深入探讨Unirest-Java的技术细节和使用方法。

Unirest-Java是一个轻量级的HTTP客户端库,它提供了简单易用的API,可以帮助Java开发人员快速地发送HTTP请求和处理响应。在本文中,我们将深入探讨Unirest-Java的技术细节和使用方法。

Unirest-Java的优点

  1. 简单易用:Unirest-Java提供了一组简单易用的API,可以帮助Java开发人员快速地发送HTTP请求和处理响应。
  2. 轻量级:Unirest-Java是一个轻量级的HTTP客户端库,它不需要任何外部依赖项,可以很容易地集成到Java应用程序中。
  3. 支持多种HTTP方法:Unirest-Java支持GET、POST、PUT和DELETE等多种HTTP方法,可以满足不同的需求。
  4. 支持异步请求:Unirest-Java支持异步请求,可以在发送请求时指定回调函数,当请求完成时自动调用回调函数。

Unirest-Java的安装和配置

Unirest-Java可以通过Maven或Gradle进行安装和配置。在Maven中,只需要在pom.xml文件中添加以下依赖项:

<!-- Pull in as a traditional dependency -->
<dependency>
    <groupId>com.konghq</groupId>
    <artifactId>unirest-java</artifactId>
    <version>3.14.1</version>
</dependency>

<!-- OR as a snazzy new standalone jar with shaded dependencies -->
<dependency>
    <groupId>com.konghq</groupId>
    <artifactId>unirest-java</artifactId>
    <version>3.14.1</version>
    <classifier>standalone</classifier>
</dependency>

Unirest-Java的使用方法

Unirest-Java提供了一组简单易用的API,可以帮助Java开发人员快速地发送HTTP请求和处理响应。

请求处理操作

所以你可能想知道使用 Unirest 如何使在 Java 中创建请求更容易,这里有一个基本的 POST 请求,它将解释一切:

HttpResponse<JsonNode> response = Unirest.post("http://localhost/post")
      .header("accept", "application/json")
      .queryString("apiKey", "123")
      .field("parameter", "value")
      .field("firstname", "Gary")
      .asJson();
调用as[Type]()时会发出请求,类型包括Json、字符串、对象空和文件

路由参数(Route Parameters)

有时您想在URL中添加动态参数,您可以通过在 URL 中添加占位符,然后使用 routeParam 函数设置路由参数来轻松完成,例如:

Unirest.get("http://localhost/{fruit}")
     .routeParam("fruit", "apple")
     .asString();

请求的结果是http://localhost/apple

  • 占位符 {水果} 将替换为apple。
  • 占位符的格式就像用大括号换行一样简单:{custom_name}
  • 所有参数值都将为您进行URL编码

默认基本的URL(Default Base URLs)

您可以配置默认基础URL,以用于不包含完整URL的所有请求,此配置将导致GET到“http: //homestar.com/runner ”。

Unirest.config().defaultBaseUrl("http://homestar.com");
   Unirest.get("/runner").asString();

查询参数(Query Parameters)

可以逐个构建查询字符串参数

Unirest.get("http://localhost")
                .queryString("fruit", "apple")
                .queryString("droid", "R2D2")
                .asString();

使用 "http://localhost?fruit=apple&droid=R2D2"进行请求Http操作。


同样,所有参数值都将进行URL编码,您还可以将查询字符串作为数组和映射传入:

Unirest.get("http://localhost")
        .queryString("fruit", Arrays.asList("apple", "orange"))
        .queryString(ImmutableMap.of("droid", "R2D2", "beatle", "Ringo"))
        .asString();

请求的内容为 "http://localhost?fruit=apple&fruit=orange&droid=R2D2&beatle=Ringo"

请求头(Headers)

可以使用标头方法添加请求标头。

Unirest.get("http://localhost")
            .header("Accept", "application/json")
            .header("x-custom-header", "hello")
            .asString();

基本身份验证(Basic Authentication)

Unirest 公开了一个快捷方式,用于在需要时执行基本身份验证。Unirest 处理 Base64 编码部分。请确保您始终通过HTTPS执行此操作!

Unirest.get("http://localhost")
            .basicAuth("user", "password1!")
            .asString();

添加了请求头 “Authorization: Basic dXNlcjpwYXNzd29yZDEh”

请求体(Body Data)

实体主体

您可以轻松地发送请求头。这是大多数REST服务的默认行为。除非另行指定,否则默认内容类型为Content-Type 是 text/plain; charset=UTF-8。

Unirest.post("http://localhost")
                .body("This is the entire body")
                .asEmpty();

还可以发布为使用配置的对象映射器序列化的对象。Unirest带有一个默认映射器,它将使用流行的Google Gson库序列化为json。

Unirest.post("http://localhost")
            .header("Content-Type", "application/json")
            .body(new SomeUserObject("Bob"))
            .asEmpty();

这将使用Jackson将对象序列化为JSON。

发送GET请求

HttpResponse<String> response = Unirest.get("http://httpbin.org/get")
  .header("accept", "application/json")
  .queryString("apiKey", "123")
  .asString();

发送POST请求

HttpResponse<String> response = Unirest.post("http://httpbin.org/post")
  .header("accept", "application/json")
  .field("param1", "value1")
  .field("param2", "value2")
  .asString();

发送PUT请求

HttpResponse<String> response = Unirest.put("http://httpbin.org/put")
  .header("accept", "application/json")
  .field("param1", "value1")
  .field("param2", "value2")
  .asString();

发送DELETE请求

HttpResponse<String> response = Unirest.delete("http://httpbin.org/delete")
  .header("accept", "application/json")
  .queryString("apiKey", "123")
  .asString();

处理响应

HttpResponse<String> response = Unirest.get("http://httpbin.org/get")
  .header("accept", "application/json")
  .queryString("apiKey", "123")
  .asString();

int status = response.getStatus();
String body = response.getBody();
Headers headers = response.getHeaders();

基本表单

基本的http名称值主体参数可以通过简单的字段调用来传递。这种类型请求的Content-Type默认为application/x-www-form-urlencoded。

Unirest.post("http://localhost")
       .field("fruit", "apple")
       .field("droid", "R2D2")
       .asEmpty();

这将发布一个与HTML表单相同的简单名称-值对主体。如:“fruit=apple&droid=R2D2”。


文件上传

你也可以采用表单的形式发布二进制数据。就像文件一样。此类型请求的内容类型默认为multipart/form-data。

Unirest.post("http://localhost")
       .field("upload", new File("/MyFile.zip"))
       .asEmpty();

对于大文件,可能需要使用InputStream。如果需要文件名,请给它一个文件名。在这里使用的是FileInputStream,但它实际上可以是任何类型的InputStream。

InputStream file = new FileInputStream(new File("/MyFile.zip"));
Unirest.post("http://localhost")
       .field("upload", file, "MyFile.zip")
       .asEmpty();

上传进度监控

如果正在上传大文件,可能需要向用户提供一些时间进度条。您可以通过提供ProgresMonitor来展示进度。

Unirest.post("http://localhost")
                .field("upload", new File("/MyFile.zip"))
           .uploadMonitor((field, fileName, bytesWritten, totalBytes) -> {
                    // 实现你的输出即可。
                })
           .asEmpty();

异步请求

大多数时候,您希望应用程序是异步的,而不是阻塞的,Unirest在Java中使用匿名回调来支持这一点。所有请求类型都支持异步版本。

CompletableFuture<HttpResponse<JsonNode>> future = Unirest.post("http://localhost/post")
  .header("accept", "application/json")
  .field("param1", "value1")
  .field("param2", "value2")
  .asJsonAsync(response -> {
        int code = response.getStatus();
        JsonNode body = response.getBody();
});

响应体

Unirest在您调用它的as〔type〕方法时发出实际请求。这些方法还通知Unirest将响应映射到什么类型。选项有Empty、String、File、Object、byte和Json。

响应返回为HttpResponse,其中HttpResponse对象具有所有常见的响应数据,如状态和标头。可以使用.getBody()方法通过所需类型访问Body(如果存在)。

Empty响应体

如果你不需要得到结果返回,asEmpty是最简单的选择。但是仍然会得到其他的响应信息。

HttpResponse response = Unirest.delete("http://localhost").asEmpty()

String响应体

最简单的响应类型是字符串。在那之后,你可以用它做任何你想做的事。

String body = Unirest.get("http://localhost")
                     .asString()
                     .getBody();

JSON响应体

当您不需要完整的Object Mapper时,Unirest提供了一种轻量级的JSON响应类型。

String result = Unirest.get("http://some.json.com")
                       .asJson()
                       .getBody()
                       .getObject()
                       .getJSONObject("car")
                       .getJSONArray("wheels")
                       .get(0)

大数据响应体

一些响应方法(asString、asJson)将整个响应流读取到内存中。为了读取原始流并处理大量响应,您可以使用以下几种功能方法:

Map r = Unirest.get(MockServer.GET)
                .queryString("firstname", "Gary")
                .asObject(i -> new Gson().fromJson(i.getContentReader(), HashMap.class))
                .getBody();
消费者模式
Unirest.get(MockServer.GET)
                .thenConsumeAsync(r -> {
                       // something like writing a file to disk
                });

Object Mapped响应体

  • 大多数时候,在使用RESTful服务时,您可能希望将响应映射到对象中。为此,您需要为Unirest配置提供ObjectMapper的实现。如果响应是JSON,那么你很幸运,Unirest附带了一个基于Google GSON的基本JsonObjectMapper。
  • 在创建asObject(类)之前,有必要提供ObjectMapper接口的自定义实现(如果您不希望使用默认映射器)。这应该只在第一次执行,因为ObjectMapper的实例将被全局共享。

Unirest提供了一些插件来实现流行的对象映射器,如Jackson和Gson。

例如

响应体的对象
Book book = Unirest.get("http://localhost/books/1")
                   .asObject(Book.class)
                   .getBody();
响应体的对象

可以通过使用GenericType子类来解析泛型类型,以避免擦除。

List<Book> books = Unirest.get("http://localhost/books/")
              .asObject(new GenericType<List<Book>>(){})
              .getBody();

直接采用反射进行获取对象

Author author = Unirest.get("http://localhost/books/{id}/author")
                       .routeParam("id", bookObject.getId())
                       .asObject(Author.class)
                       .getBody();

总结

Unirest-Java是一个简单易用、轻量级的HTTP客户端库,它提供了多种HTTP方法和异步请求支持,可以帮助Java开发人员快速地发送HTTP请求和处理响应。如果你正在寻找一个简单易用的HTTP客户端库,那么Unirest-Java是一个不错的选择。

相关文章
|
4天前
|
JSON Java Apache
非常实用的Http应用框架,杜绝Java Http 接口对接繁琐编程
UniHttp 是一个声明式的 HTTP 接口对接框架,帮助开发者快速对接第三方 HTTP 接口。通过 @HttpApi 注解定义接口,使用 @GetHttpInterface 和 @PostHttpInterface 等注解配置请求方法和参数。支持自定义代理逻辑、全局请求参数、错误处理和连接池配置,提高代码的内聚性和可读性。
|
9天前
|
JSON 前端开发 JavaScript
java-ajax技术详解!!!
本文介绍了Ajax技术及其工作原理,包括其核心XMLHttpRequest对象的属性和方法。Ajax通过异步通信技术,实现在不重新加载整个页面的情况下更新部分网页内容。文章还详细描述了使用原生JavaScript实现Ajax的基本步骤,以及利用jQuery简化Ajax操作的方法。最后,介绍了JSON作为轻量级数据交换格式在Ajax应用中的使用,包括Java中JSON与对象的相互转换。
18 1
|
16天前
|
SQL 监控 Java
技术前沿:Java连接池技术的最新发展与应用
本文探讨了Java连接池技术的最新发展与应用,包括高性能与低延迟、智能化管理和监控、扩展性与兼容性等方面。同时,结合最佳实践,介绍了如何选择合适的连接池库、合理配置参数、使用监控工具及优化数据库操作,为开发者提供了一份详尽的技术指南。
23 7
|
14天前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
30 3
|
14天前
|
SQL 监控 Java
Java连接池技术的最新发展,包括高性能与低延迟、智能化管理与监控、扩展性与兼容性等方面
本文探讨了Java连接池技术的最新发展,包括高性能与低延迟、智能化管理与监控、扩展性与兼容性等方面。同时,结合最佳实践,介绍了如何选择合适的连接池库、合理配置参数、使用监控工具及优化数据库操作,以实现高效稳定的数据库访问。示例代码展示了如何使用HikariCP连接池。
9 2
|
16天前
|
Java 数据库连接 数据库
优化之路:Java连接池技术助力数据库性能飞跃
在Java应用开发中,数据库操作常成为性能瓶颈。频繁的数据库连接建立和断开增加了系统开销,导致性能下降。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接,显著减少连接开销,提升系统性能。文章详细介绍了连接池的优势、选择标准、使用方法及优化策略,帮助开发者实现数据库性能的飞跃。
23 4
|
17天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
14天前
|
Java 数据库连接 数据库
深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能
在Java应用开发中,数据库操作常成为性能瓶颈。本文通过问题解答形式,深入探讨Java连接池技术如何通过复用数据库连接、减少连接建立和断开的开销,从而显著提升系统性能。文章介绍了连接池的优势、选择和使用方法,以及优化配置的技巧。
16 1
|
14天前
|
算法 Java 数据库连接
Java连接池技术,从基础概念出发,解析了连接池的工作原理及其重要性
本文详细介绍了Java连接池技术,从基础概念出发,解析了连接池的工作原理及其重要性。连接池通过复用数据库连接,显著提升了应用的性能和稳定性。文章还展示了使用HikariCP连接池的示例代码,帮助读者更好地理解和应用这一技术。
29 1
|
16天前
|
SQL Java 数据库连接
打破瓶颈:利用Java连接池技术提升数据库访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,避免了频繁的连接建立和断开,显著提升了数据库访问效率。常见的连接池库包括HikariCP、C3P0和DBCP,它们提供了丰富的配置选项和强大的功能,帮助优化应用性能。
34 2