Netty4.0的DefaultHttpRequest与FullHttpRequest

本人用netty4.0做Http服务器模块时,出现了一个Bug,从平台发送过来的充值请求接收不到,充值请求是Post方式,自己写了个post工具模拟充值请求,发现:能收到HttpRequest,但收不到HttpContent。

消息分发器代码:

	protected void channelRead0(ChannelHandlerContext ctx, Object data)
			throws Exception {
if (data instanceof HttpRequest) {
.....
}
else if(data instanceof HttpContent){
....
}
}

这是以前没出问题时的部分代码,Post请求是分两次收到的,一次是HttpRequest,只有Http 协议头,一次是HttpContent,内容是data form数据。


消息处理链代码:

		ChannelPipeline pipeline = channel.pipeline();
		pipeline.addLast(new HttpServerCodec());
		pipeline.addLast(HANDLER);

之后修改了消息处理链的代码,因为不能响应太长数据消息:

	@Override
	protected void initChannel(SocketChannel channel) throws Exception {
		ChannelPipeline pipeline = channel.pipeline();
		pipeline.addLast(new HttpServerCodec());
		pipeline.addLast( new HttpObjectAggregator(65536));
		pipeline.addLast(new ChunkedWriteHandler());
//		pipeline.addLast(new HttpRequestDecoder());
		pipeline.addLast(HANDLER);

添加HttpObjectAggregator和ChunkedWriteHandler,结果就出现了这个问题

相应的分发器代码也要改

	protected void channelRead0(ChannelHandlerContext ctx, Object data)
			throws Exception {
		//DefaultHttpRequest
		//FullHttpRequest
		if(data instanceof FullHttpRequest){
			FullHttpRequest fhr = (FullHttpRequest)data;
			String uri = fhr.getUri();
			int platType = -1;
			int action = 0;
			if(uri.startsWith("/exchange")){
				platType = PlatformTypes.QIHOO;
				action = PlatformManager.ACTION_EXCHANGE;
				int len = fhr.content().readableBytes();
				if(len > 0){
					byte[] content = new byte[len];
					fhr.content().readBytes(content);
					String contentStr = new String(content, "UTF-8");
					Map<String, String> paramMap = HttpUtil.url2Map(contentStr);
					PlatformManager.getInstance().doAction(platType, action, paramMap, ctx.channel());
				}
				return;
			}
		}

FullHttpRequest的协议头和Form数据是在一起的,不用分开读,之前分开接收的是DefaultHttpRequest与HttpContent,FullHttpRequest把两者合在一起了,Netty不熟悉就是容易出错。

### 回答1: Netty 4.0Netty 3.0 的区别有以下几点: 1. 支持的 Java 版本:Netty 4.0 支持的 Java 版本是 Java 7 及以上,而 Netty 3.0 只支持 Java 6 及以上。 2. 架构改变:Netty 4.0 在架构上做了很大的改变,使用了与 3.0 不同的组件和 API。 3. 性能提升:Netty 4.0 在性能上有了很大的提升,比 3.0 快得多。 4. 异步改进:Netty 4.0 对异步操作进行了改进,使用了更加高效的方式来处理异步任务。 5. 新的编解码器:Netty 4.0 新增了一些编解码器,支持更多的协议。 6. 更多的优化:Netty 4.0 还进行了更多的优化,比如支持堆外内存、增强的零拷贝等。 ### 回答2: Netty 4.0Netty 3.0是Java网络编程框架Netty的两个版本。它们之间存在以下区别: 1. 性能提升:Netty 4.0相较于Netty 3.0在性能方面有显著提升。Netty 4.0经过了全面的优化和重构,引入了许多新的特性和改进,使其在处理网络通信时更加高效。 2. API的变化:Netty 4.0对API进行了重构和简化,使得编程接口更加易用和灵活。比如,Netty 4.0引入了ChannelPipelineHandler的概念,可以更加方便地添加和管理多个处理器。 3. 事件处理模型:Netty 4.0采用了新的事件处理模型,即Reactor模型,使得在高并发场景下的事件处理更加高效。而Netty 3.0采用的是NIO Selector模型。 4. 内存管理:Netty 4.0引入了更高级的内存管理机制,即ByteBuf和Recycler。ByteBuf提供了更加灵活的内存分配和回收方式,减少了内存的创建和销毁开销。Recycler可以对对象进行重用,减少了频繁的对象创建和垃圾回收开销。 5. 异常处理:Netty 4.0对异常处理进行了优化,提供了更加丰富的异常类型和处理方式。Netty 3.0在异常处理方面相对简单。 总的来说,Netty 4.0相较于Netty 3.0在性能、API设计、事件处理模型、内存管理和异常处理方面都有较大的改进和优化。因此,Netty 4.0更加适合开发高性能、高并发的网络应用程序。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值