1.说明
在webflux接收请求时,第一步实际上 netty-reacto r将 channel 中的字节信息解析成msg(netty-reactor的解析),进而解析成request,之后才是webflux的处理流程。
实践中发现,当调用接口时若request存在异常,代码不会执行到业务代码,且不会有异常日志,初遇到时很让人困惑。
此处梳理request的解析链路,重点关注异常request的处理。
2. 代码路径
接收解析channel中的byte数据,并解码成massage:
io.netty.handler.codec.ByteToMessageDecoder#channelRead
之后遍历处理解析到的msg:
io.netty.handler.codec.ByteToMessageDecoder#fireChannelRead
之后的处理中,会进一步封装request :
reactor.netty.http.server.HttpTrafficHandler#channelRead
返回错误信息时,response是框架层面定义的,没有response body,需要根据http code判断
reactor.netty.http.server.HttpServerOperations#sendDecodingFailures