导读 | Forest v1.5.30 发布,适配 SpringBoot3 和 Solon,新增延迟参数 |
Forest 是一个开源的 Java HTTP 客户端框架,它能够将 HTTP 的所有请求信息(包括 URL、Header 以及 Body 等信息)绑定到您自定义的 Interface 方法上,能够通过调用本地接口方法的方式发送 HTTP 请求
2021 年度 OSC 中国开源项目评选「最受欢迎项目」
2022 年度 OSC 中国开源项目评选「最火热中国开源项目社区」
创建一个 interface,并用 @Get 注解修饰接口方法。
public interface MyClient { @Get("//localhost:8080/hello") String hello(); }
通过 @Get 注解,将上面的 MyClient 接口中的 simpleRequest() 方法绑定了一个 HTTP 请求, 其 URL 为 //localhost:8080/hello,并默认使用 GET 方式,且将请求响应的数据以 String 的方式返回给调用者
Forest.get("//localhost:8080/hello").execute();
编程式接口则更为简单直接
支持和适配了 SpringBoot3
支持和适配了 Solon 框架
支持延迟参数特性
有很多情况,Header、Query、Body 的参数值不能马上得出,而是在请求发送前的那一刻(所有请求参数都到位时)才能得出,典型的例子就是加签验证的场景(在 Header 中添加一个参数 token,而 token 的值是对整个 body 做加密的结果)
请求头的延迟参数
Forest.post("/test") .addHeader("Content-Type", "application/json; charset=UTF-8") // 普通请求头 .addHeader("Authorization", req -> Base64.encode(req.body().encode())) // 延迟请求头 .addBody("id", "1972664191") // 请求体参数 id .addBody("name", "XieYu20011008") // 请求体参数 name .execute();
请求体的延迟参数
Forest.post("/test") .addHeader("Content-Type", "application/json; charset=UTF-8") // 请求头 .addHeader("_id", "20011008") // 请求头 .addBody("id", "1972664191") // 请求体参数 id .addBody("name", req -> "Foo" + req.headerValue("_id")) // 延迟请求体参数 name .addBody("token", req -> Base64.encode(req.body().encode())) // 延迟请求体参数 token .execute(); // 执行请求
官网地址:
//forest.dtflyx.com
Gitee 仓库地址:
//gitee.com/dromara/forest
Github 仓库地址:
//github.com/dromara/forest
原文来自:
本文地址://q13zd.cn/fvfb.html编辑:王婷,审核员:清蒸github
Linux大全:
Linux系统大全: