基于Netty5.0入门案例七之NettyClient
前言介绍:
前面案例一到六我们介绍了服务端最基本的内容,现在我们来学习一下客户端的例子。
客户端与服务端的基本写法相似,半包粘包处理也没有区别。
欢迎加入:itstack | Netty The Sniper 5360692
环境需求:
1、jdk1.7以上【jdk1.7以下只能部分支持netty】
2、Netty-all-5.0【netty3.x 4.x 5每次的变化较大,接口类名也随着变化】
3、telnet 测试【可以现在你的win7机器上测试这个命令,用于链接到服务端的测试命令】【本案例中已经很不好满足测试需求了】
4、最好下载个网络调试助手,它能帮助你测试服务端、客户端
代码部分:
======================
TestNettyClientBaseDemo
src
com.itstack
ChildChannelHandler.java
NettyClient.java
======================
ChildChannelHandler.java
- package com.itstack;
- import io.netty.channel.ChannelInitializer;
- import io.netty.channel.socket.SocketChannel;
- public class ChildChannelHandler extends ChannelInitializer<SocketChannel>{
- @Override
- protected void initChannel(SocketChannel e) throws Exception {
- System.out.println("客户端链接到服务端");
- }
- }
NettyClient.java
- package com.itstack;
- import io.netty.bootstrap.Bootstrap;
- import io.netty.channel.ChannelFuture;
- import io.netty.channel.ChannelOption;
- import io.netty.channel.EventLoopGroup;
- import io.netty.channel.nio.NioEventLoopGroup;
- import io.netty.channel.socket.nio.NioSocketChannel;
- public class NettyClient {
- public static void main(String[] args) {
- try {
- new NettyClient().connect("192.168.30.223", 7397);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- public void connect(String inetHost,int inetPort) throws Exception{
- EventLoopGroup group = new NioEventLoopGroup();
- try {
- Bootstrap b = new Bootstrap();
- b.group(group); //group 组
- b.channel(NioSocketChannel.class); //channel 通道
- b.option(ChannelOption.TCP_NODELAY, true); //option 选项
- b.handler(new ChildChannelHandler()); //handler 处理
- //发起异步链接
- ChannelFuture f = b.connect(inetHost, inetPort);
- //等待客户端链路关闭
- f.channel().closeFuture().sync();
- } finally{
- group.shutdownGracefully();
- }
- }
- }
1、启动网络调试助手模拟软件,开启一个服务端
2、启动NettyClient
3、控制台输出
----------------------------------------------
客户端链接到服务端
----------------------------------------------
posted on 2015-01-12 17:07 bugstack虫洞栈 阅读(258) 评论(0) 收藏 举报
浙公网安备 33010602011771号