客户端:

package com.server;
import java.net.Socket;
public class Client {
public static void main(String[] args) throws Exception {
Socket socket = new Socket("127.0.0.1", 10101);
socket.getOutputStream().write("hello".getBytes());
socket.close();
}
}

服务端:

package com.server;

import java.net.InetSocketAddress;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; import org.jboss.netty.bootstrap.ServerBootstrap;
import org.jboss.netty.channel.ChannelPipeline;
import org.jboss.netty.channel.ChannelPipelineFactory;
import org.jboss.netty.channel.Channels;
import org.jboss.netty.channel.socket.nio.NioServerSocketChannelFactory;
import org.jboss.netty.handler.codec.string.StringDecoder;
import org.jboss.netty.handler.codec.string.StringEncoder; public class Server {
public static void main(String[] args) {
//服务类
ServerBootstrap bootstrap = new ServerBootstrap();
//boss线程监听端口,worker线程负责数据读写
ExecutorService boss = Executors.newCachedThreadPool();
ExecutorService worker = Executors.newCachedThreadPool();
//设置niosocket工厂
bootstrap.setFactory(new NioServerSocketChannelFactory(boss, worker));
//设置管道的工厂
bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
@Override
public ChannelPipeline getPipeline() throws Exception { ChannelPipeline pipeline = Channels.pipeline();
pipeline.addLast("handler1", new MyHandler1());
pipeline.addLast("handler2", new MyHandler2());
return pipeline;
}
});
bootstrap.bind(new InetSocketAddress(10101));
System.out.println("start!!!");
}
}
package com.server;

import org.jboss.netty.buffer.ChannelBuffer;
import org.jboss.netty.channel.ChannelHandlerContext;
import org.jboss.netty.channel.MessageEvent;
import org.jboss.netty.channel.SimpleChannelHandler;
import org.jboss.netty.channel.UpstreamMessageEvent; public class MyHandler1 extends SimpleChannelHandler {
@Override
public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) throws Exception {
ChannelBuffer buffer = (ChannelBuffer)e.getMessage();
byte[] array = buffer.array();
String message = new String(array);
System.out.println("handler1:" + message);
//传递
ctx.sendUpstream(new UpstreamMessageEvent(ctx.getChannel(), "abc", e.getRemoteAddress()));
ctx.sendUpstream(new UpstreamMessageEvent(ctx.getChannel(), "efg", e.getRemoteAddress()));
}
}
package com.server;

import org.jboss.netty.channel.ChannelHandlerContext;
import org.jboss.netty.channel.MessageEvent;
import org.jboss.netty.channel.SimpleChannelHandler; public class MyHandler2 extends SimpleChannelHandler {
@Override
public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) throws Exception {
String message = (String)e.getMessage();
System.out.println("handler2:" + message);
}
}

最新文章

  1. oracle函数简析
  2. 数据库—SQL语句
  3. 即将翻译 Building The New Financial Times Web App
  4. Spring aop——前置增强和后置增强 使用注解Aspect和非侵入式配置
  5. 在php中,如何将一个页面中的标签,替换为用户想输出的内容
  6. ActiveMQ学习(三)——MQ的通讯模式
  7. PHP内核探索:哈希碰撞攻击是什么?
  8. checkbox改成radio效果,单选,取消
  9. C++运算符重载(10)
  10. 使用Apache Commons Email 发生邮件
  11. 11-散列4 Hashing - Hard Version
  12. odoo开发笔记 -- self详解
  13. Python 高级面向对象
  14. (下一篇博客)提示5G信道
  15. Linux kernel 发布 5.0-rc1 版本
  16. Springmvc的handler method参数绑定常用的注解
  17. java struts2入门学习实例--使用struts进行验证
  18. C# DateTime 月第一天和最后一天 取法
  19. Solr学习之二-Solr基础知识
  20. spectre漏洞代码分析-c代码

热门文章

  1. box-sizing在什么情况下会失效
  2. 如何改变placeholder的样式
  3. ios模拟器键盘不弹出
  4. std::mutex
  5. Socket连接何时需要断开
  6. setMasksToBounds
  7. The Model represents your data structures.
  8. SOI简单体验
  9. POJ1470Closest Common Ancestors 最近公共祖先LCA 的 离线算法 Tarjan
  10. Ponds----hdu5438(拓扑排序)