Netty服务端和客户端处理字符串的消息的简单例子
服务端
服务端启动类:
package com.zqw.nio.netty.n2;
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;
import java.net.InetSocketAddress;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Server1 {
public static void main(String[] args) {
ServerBootstrap bootstrap = new ServerBootstrap();
ExecutorService boss = Executors.newCachedThreadPool();
ExecutorService work = Executors.newCachedThreadPool();
bootstrap.setFactory(new NioServerSocketChannelFactory(boss, work));
bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
@Override
public ChannelPipeline getPipeline() throws Exception {
ChannelPipeline channelPipeline = Channels.pipeline();
channelPipeline.addLast("encoder", new StringEncoder());
channelPipeline.addLast("decoder", new StringDecoder());
channelPipeline.addLast("serverHiHandler1", new ServerHiHandler1());
return channelPipeline;
}
});
bootstrap.bind(new InetSocketAddress(7777));
System.out.println("netty服务端已经启动!");
}
}
服务端处理类:
package com.zqw.nio.netty.n2;
import org.jboss.netty.channel.*;
public class ServerHiHandler1 extends SimpleChannelHandler {
public ServerHiHandler1() {
super();
}
@Override
public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) throws Exception {
String s = (String) e.getMessage();
System.out.println("服务端接收到消息:" + s);
ctx.getChannel().write("返回客户端一个消息:你好," + s );
super.messageReceived(ctx, e);
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx, ExceptionEvent e) throws Exception {
super.exceptionCaught(ctx, e);
}
@Override
public void channelOpen(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelOpen(ctx, e);
}
@Override
public void channelConnected(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelConnected(ctx, e);
}
@Override
public void channelDisconnected(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelDisconnected(ctx, e);
}
@Override
public void channelClosed(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelClosed(ctx, e);
}
}
客户端
客户端启动类:
package com.zqw.nio.netty.n2;
import org.jboss.netty.bootstrap.ClientBootstrap;
import org.jboss.netty.channel.*;
import org.jboss.netty.channel.socket.nio.NioClientSocketChannelFactory;
import org.jboss.netty.handler.codec.string.StringDecoder;
import org.jboss.netty.handler.codec.string.StringEncoder;
import java.net.InetSocketAddress;
import java.util.Scanner;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Client1 {
public static void main(String[] args) {
ClientBootstrap bootstrap = new ClientBootstrap();
ExecutorService boss = Executors.newCachedThreadPool();
ExecutorService work = Executors.newCachedThreadPool();
bootstrap.setFactory(new NioClientSocketChannelFactory(boss, work));
bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
@Override
public ChannelPipeline getPipeline() throws Exception {
ChannelPipeline pipeline = Channels.pipeline();
pipeline.addLast("encoder", new StringEncoder());
pipeline.addLast("decoder", new StringDecoder());
pipeline.addLast("hiClientHandler", new ClientHiHandler1());
return pipeline;
}
});
ChannelFuture channelFuture = bootstrap.connect(new InetSocketAddress("localhost", 7777));
Channel channel = channelFuture.getChannel();
System.out.println("netty客户端连接了!");
Scanner scanner = new Scanner(System.in);
while(true){
System.out.println("请输入:");
channel.write(scanner.next());
}
}
}
客户端处理类:
package com.zqw.nio.netty.n2;
import org.jboss.netty.channel.ChannelHandlerContext;
import org.jboss.netty.channel.ChannelStateEvent;
import org.jboss.netty.channel.MessageEvent;
import org.jboss.netty.channel.SimpleChannelHandler;
public class ClientHiHandler1 extends SimpleChannelHandler {
public ClientHiHandler1() {
super();
}
@Override
public void messageReceived(ChannelHandlerContext ctx, MessageEvent e) throws Exception {
String s = (String) e.getMessage();
System.out.println(s);
// ctx.getChannel().write("你好啊,我收到了你的消息:" + s);
super.messageReceived(ctx, e);
}
@Override
public void channelOpen(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelOpen(ctx, e);
}
@Override
public void channelDisconnected(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelDisconnected(ctx, e);
}
@Override
public void channelClosed(ChannelHandlerContext ctx, ChannelStateEvent e) throws Exception {
super.channelClosed(ctx, e);
}
}