package luck.spring.boot.webflux;
import cn.hutool.core.date.DateUtil;
import lombok.SneakyThrows;
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.io.buffer.DataBuffer;
import org.springframework.core.io.buffer.DataBufferFactory;
import org.springframework.http.server.reactive.HttpHandler;
import org.springframework.http.server.reactive.ReactorHttpHandlerAdapter;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.http.server.reactive.ServerHttpResponse;
import reactor.core.publisher.Mono;
import reactor.netty.http.server.HttpServer;
import java.nio.charset.StandardCharsets;
@Slf4j
public class NettyHttpHandlerDemo {
// 测试原生的启用服务器,使用指定的处理器处理请求
@SneakyThrows
public static void main(String[] args) {
// http的请求处理器
HttpHandler handler = new HttpHandler() {
@Override
public Mono<Void> handle(ServerHttpRequest request, ServerHttpResponse response) {
String address = request.getRemoteAddress().getAddress().getHostAddress();
log.error("ip is {}", address);
// 提供一个生产Buffer数据的工厂
DataBufferFactory bufferFactory = response.bufferFactory();
// 生产Buffer类型的数据
DataBuffer buffer = bufferFactory.wrap(address.getBytes(StandardCharsets.UTF_8));
// 响应数据
return response.writeWith(Mono.just(buffer));
}
};
String host = "localhost";
int port = 8080;
ReactorHttpHandlerAdapter adapter = new ReactorHttpHandlerAdapter(handler);
ReactorHttpHandlerAdapter adapter2 = new ReactorHttpHandlerAdapter(handler);
// 启动web服务器,有adapter来处理
HttpServer.create().host(host).port(port)
// 每一个handler都会执行,用于处理http请求
.handle(adapter)
.handle(adapter2)
.bindNow();
log.error("服务器启动:{}", DateUtil.now());
System.in.read();
log.error("服务器关闭:{}", DateUtil.now());
}
}
使用Netty作为Web服务器与原生API实现WebFlux的效果
最新推荐文章于 2026-02-25 20:30:21 发布

2285

被折叠的 条评论
为什么被折叠?



