Netty HttpServerCodec和HttpObjectAggregator

GET请求

Get请求包括两个部分:

request line(包括method,request uri,protocol version))

header

HttpServerCodec是netty针对http编解码的处理类,但是这些只能处理像http get的请求,也就是数据带在url问号后面的http请求参数

POST请求

POST请求包括三个部分

request line(包括method,request uri,protocol version))

header

message body

从上可以看出,当我们用POST方式请求服务器的时候,对应的参数信息是保存在message body中的,如果只是单纯的用HttpServerCodec是无法完全的解析Http POST请求的,因为HttpServerCodec只能获取uri中参数,所以需要加上HttpObjectAggregator。

HttpObjectAggregator这个netty的处理器就是为了解决这个问题而来的.它把HttpMessage和HttpContent聚合成为一个FullHttpRquest或者FullHttpRsponse,大致结构如下图所示:

复制代码
public class ChannelHandlerInitializer extends ChannelInitializer<SocketChannel> {

	@Override
	protected void initChannel(SocketChannel ch) throws Exception {

		// HTTP编码解码器
		ch.pipeline().addLast("http-codec", new HttpServerCodec());
		// 把HTTP头、HTTP体拼成完整的HTTP请求
		ch.pipeline().addLast("aggregator", new HttpObjectAggregator(65536));
        // httpRequestHandler 中获取到的就是一个完整的Http消息了
		ch.pipeline().addLast("http-handler", httpRequestHandler);
	}

}
相关推荐
吗喽对你问好9 分钟前
23种设计模式解释+记忆
java·设计模式
188_djh16 分钟前
# 终端执行 java -jar example.jar 时(example.jar为项目jar包)报错:“没有主清单属性” 的解决方法
java·pycharm·jar·cmd·没有主清单属性·java -jar
CodeClimb29 分钟前
【华为OD-B卷-打印文件 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
C1829818257535 分钟前
Rocketmq刷盘机制和复制机制区别及关系
java·rocketmq·java-rocketmq
D.eL44 分钟前
设计模式7大原则与UML类图详解
java·设计模式·uml
Eric.Lee20211 小时前
ROS2 pkg 创建功能包
java·linux·开发语言
OneT1me1 小时前
SN生成流水号并且打乱
java·linux·前端
Auc241 小时前
物流项目第四期(运费模板列表实现)
java·windows·docker·微服务·架构·策略模式
天黑请闭眼1 小时前
ShardingSphere:查询报错:Actual table `数据源名称.表名` is not in table rule configuration
java
Uranus^1 小时前
深入解析Spring Boot与微服务架构:从入门到实践
java·spring boot·spring cloud·微服务