Forest v1.5.26 发布!声明式 HTTP 框架

来源: 投稿
2022-08-11 11:51:00

Forest介绍

Forest 是一个开源的 Java HTTP 客户端框架,它能够将 HTTP 的所有请求信息(包括 URL、Header 以及 Body 等信息)绑定到您自定义的 Interface 方法上,能够通过调用本地接口方法的方式发送 HTTP 请求

Forest 如何使用

Forest 不需要您编写具体的 HTTP 调用过程,只需要您定义一个接口,然后通过 Forest 注解将 HTTP 请求的信息添加到接口的方法上即可。请求发送方通过调用您定义的接口便能自动发送请求和接受请求的响应

Forest 的工作原理

Forest 会将您定义好的接口通过动态代理的方式生成一个具体的实现类,然后组织、验证 HTTP 请求信息,绑定动态数据,转换数据形式,SSL 验证签名,调用后端 HTTP API(httpclient 等 API)执行实际请求,等待响应,失败重试,转换响应数据到 Java 类型等脏活累活都由这动态代理的实现类给包了。 请求发送方调用这个接口时,实际上就是在调用这个干脏活累活的实现类

获得奖项

2021 年度 OSC 中国开源项目评选「最受欢迎项目」

相关链接: https://www.oschina.net/project/top_cn_2021

一个栗子

定义请求接口

public interface MyClient {

    @Get("http://localhost:8080/hello")
    String helloRequest();

}

发送请求

// 注入自定义的 Forest 接口实例
@Resource
private MyClient myClient;

public void testClient() {
    // 调用自定义的 MyClient 接口方法
    // 等价于发送 HTTP 请求,请求地址和参数即为 helloRequest 方法上注解所标识的内容
    String result = myClient.helloRequest();
    // result 即为 HTTP 请求响应后返回的字符串类型数据
    System.out.println(result);
}

声明式接口

// 高德地图API
public interface AmapClient {
    /**
     * 根据经纬度查询地址信息
     * 在url中的{0}代表引用第一个参数,{1}引用第二个参数
     */
    @Get("http://ditu.amap.com/service/regeo")
    Map getLocation(@Query("longitude") String longitude, @Query("latitude") String latitude);
}

编程式接口

// 定义各种参数
// 并以 Map 类型接受
Map<String, Object> map = Forest.post("/data")
      .host("localhost")         // 设置地址的host为 127.0.0.1
      .port(8080)                // 设置地址的端口为 8080
      .contentTypeJson()         // 设置 Content-Type 头为 application/json
      .addBody("a", 1)           // 添加 Body 项(键值对): a, 1
      .addBody("b", 2)           // 添加 Body 项(键值对:  b, 2
      .executeAsMap();           // 执行并返回Map数据类型对象

官网和仓库地址

官网地址:

http://forest.dtflyx.com

Gitee 仓库地址:

https://gitee.com/dromara/forest

Github 仓库地址:

https://github.com/dromara/forest

本次更新内容

  • feat: 在使用 OkHttp3 后端情况下,允许Query参数不转义大括号 (#I5ITW9)
  • feat: 在使用 OkHttp3 时绕过空 Multipart 错误 (#I5I1AC)
  • fix: 默认自动绕过SSL验证
  • fix: 声明的接口返回类型如果是String(或其他Charsequencel类型)导致自定义converter (#I5L2P6)
  • fix: okhttp后端自动将charset=UTF-8转成了小写 (#I5L4AS)
  • fix: url域名信息参数赋值会自动参数后添加”/“符号路径导致错误 (#I5I62P)
  • fix: URL路径中的$字符会被转义
  • fix: 请求的ForestURL的ssl属性没有继承类里@BaseRequest的ssl信息 (#I5HXHX)
  • update: 更新 spring 版本到5.3.19
  • update: 更新 spring boot 版本到2.6.7
展开阅读全文
点击引领话题📣 发布并加入讨论🔥
0 评论
7 收藏
分享
返回顶部
顶部