spring-boot之webflux简单入门 - 中
前言
昨天我们通过一个简单实例,演示了webflux
与WebMVC
的简单区别,同时也展示了webflux
的基本工作流程,今天我来继续学习webflux
的相关知识。
今天我们学习的重点是webflux
的客户端,我们想通过webflux
客户端来了解webflux
的相关基础知识,包括接口请求方式、响应类别、传参等
webflux客户端
简单示例
webflux
的客户端用起来很方便,也很简单,我们先看这样一段代码:
WebClient client = WebClient.create("http://localhost:8999");
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.attribute("name", "syske")
.accept(MediaType.APPLICATION_JSON)
.retrieve()
.bodyToMono(String.class);
String block = stringMono.block();
System.out.println("返回结果:" + block);
第一行代码就是实例化一个weClient
对象,需要注意的是,这里实例化的时候,也可以不指定服务器地址,如果不指定服务器地址的话,就需要我们在uri
方法中指定完整的接口地址:
WebClient client = WebClient.create();
Mono<String> stringMono = client.get()
.uri("http://localhost:8999/webflux/hi")
···
如果不指定服务器地址,且uri
填写相对接口地址,则会报如下错误信息:
示例讲解
下面我们就来详细解释下上面webfluxClient
的代码。
请求类型
client.get()
表示创建一个get
请求对象(本质上是一个RequestHeadersUriSpec
对象),他还支持post
、put
、delete
和options
,也就是我们restful
的所有协议。
对于不同的请求类型,我们配置的请求参数是不一样的,但是uri
方法都是通用的。
get
客户端配置
当然,还有很多配置项是不一样的,在上面的示例中,我们是get
请求,我们可以配置如下参数:
请求地址中的参数:也就是 url
中的参数,可以通过attributes
方法设置
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.attribute("name", "syske")
···
cookie
信息
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.cookie("syske", "yyds")
···
响应头的字符编码
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.acceptCharset(Charset.defaultCharset())
···
设置响应类型
也就是我们常用的媒体类型,包括application/json
、application/pdf
、text/html
、image/jpeg
等待
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.accept(MediaType.APPLICATION_JSON)
···
获取响应设置对象
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.retrieve()
···
配置响应对象
这里配置的类型要与服务器端对应,否则会在类型转换时报错
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.bodyToMono(String.class);
···
执行调用,获取响应数据
经过我的测试,我发现真正调用服务器是在我们执行block
方法之后,之前的操作都是未来配置客户端请求数据。
String block = stringMono.block();
post客户端配置
对于post
配置,除了我们前面和get
一样的配置外(get
的都支持),它还支持以下参数:
设置请求头类型
Mono<String> stringMono2 = client.post()
.uri("/webflux/hi")
.acceptCharset(Charset.defaultCharset())
.header("token:1234567")
.contentType(MediaType.APPLICATION_JSON)
设置其他请求头信息
Mono<String> stringMono2 = client.post()
.uri("/webflux/hi")
.headers(httpHeaders -> {
httpHeaders.add(HttpHeaders.ACCEPT_CHARSET, "UTF-8");
})
好了,客户端的相关配置就先到这里吧,下面简单测试下。
测试
下面我们分别运行get
和post
两种客户端,访问我们的两个接口,看下效果。
首选是我们的接口,第一个是get
接口,第二个是post
接口:
接口路由配置
测试代码如下
public static void main(String[] args) {
WebClient client = WebClient.create("http://localhost:8999");
Mono<String> stringMono = client.get()
.uri("/webflux/hi")
.acceptCharset(Charset.defaultCharset())
.header("token:1234567")
.cookie("syske", "yyds")
.attribute("name", "syske")
.accept(MediaType.APPLICATION_JSON)
.retrieve()
.bodyToMono(String.class);
String block = stringMono.block();
System.out.println("返回结果:" + block);
Mono<String> stringMono2 = client.post()
.uri("/webflux/hi2")
.acceptCharset(Charset.defaultCharset())
.header("token:1234567")
.headers(httpHeaders -> {
httpHeaders.add(HttpHeaders.ACCEPT_CHARSET, "UTF-8");
})
.contentType(MediaType.APPLICATION_JSON)
.cookie("syske", "yyds")
.attribute("name", "syske")
.accept(MediaType.APPLICATION_JSON)
.retrieve()
.bodyToMono(String.class);
String block1 = stringMono2.block();
System.out.println("block1" + block1);
}
然后运行下看看:
可以看到我们前面设置的数据都可以拿到,比如cookie
、contentType
。
下面是运行结果:
总结
今天时间有点紧张,搞了一天企业微信isv
环境,现在环境还是时好时坏,而且中午时间也比较紧张,所以webflux
的相关内容也就没梳理完,不过webfluxClient
也算基本上分享完了,明天继续来分享webflux
其他相关知识。