Netty客户端发送数据给服务器的两个通道(1)

EventLoopGroup group = new NioEventLoopGroup();// 设置的连接group。

Bootstrap bootstrap = new Bootstrap().group(group).option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 10000) // 超时时间。

.channel(NioSocketChannel.class).handler(new ChannelInitializer() {

@Override

public void initChannel(SocketChannel ch) throws Exception {

ch.pipeline().addLast(new JsonObjectDecoder());

ch.pipeline().addLast(new StringEncoder(CharsetUtil.UTF_8));// String解码。

ch.pipeline().addLast(new StringDecoder(CharsetUtil.UTF_8));// String解码。

ch.pipeline().addLast(new MyChannelHandlerAdapter());//

}

});

try {

System.out.println("客户端连接服务器...");

ChannelFuture channelFuture = bootstrap.connect("127.0.0.1", SERVER_PORT)

.addListener(new ChannelFutureListener() {

public void operationComplete(ChannelFuture future) throws Exception {

if (future.isSuccess()) {

// 第一种方法。

// Netty在这里发送数据。

// sendDataToServer(future.channel());

}

}

}).sync();

// 等待连接关闭。

channelFuture.channel().closeFuture().sync();

} catch (Exception e) {

e.printStackTrace();

}

}

/**

  • 发送数据到服务器端。

  • @throws Exception

*/

private void sendDataToServer(Channel channel) throws Exception {

Date date = new Date(System.currentTimeMillis());

SimpleDateFormat sdf = new SimpleDateFormat("MM-dd,HH:mm:ss:SSS");

while (true) {

date.setTime(System.currentTimeMillis());

channel.writeAndFlush("客户端@" + sdf.format(date));

System.out.println("客户端发送数据:" + sdf.format(date));

Thread.sleep(1000);

}

}

private class MyChannelHandlerAdapter extends ChannelHandlerAdapter {

// 连接激活。

@Override

public void channelActive(ChannelHandlerContext ctx) throws Exception {

super.channelActive(ctx);

System.out.println("channelActive:" + ctx.channel().remoteAddress());

// 第二种方法。

// 连接可用激活后,Netty开始往服务器端发送数据。

sendDataToServer(ctx.channel());

}

@Override

public void channelInactive(ChannelHandlerContext ctx) throws Exception {

super.channelInactive(ctx);

System.out.println("channelInactive:" + ctx.channel().remoteAddress());

}

@Override

public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {

super.channelRead(ctx, msg);

}

@Override

public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {

super.channelReadComplete(ctx);

System.out.println(ctx.channel().remoteAddress() + "读写完成");

}

}

public static void main(String[] args) {

try {

new App();

} catch (Exception e) {

e.printStackTrace();

}

}

// 服务器端。演示作为服务器接受来自客户端的数据。

private class Server extends Thread {

private ServerSocket serverSocket;

public Server() throws Exception {

serverSocket = new ServerSocket(SERVER_PORT);

}

@Override

public void run() {
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

我这里整理了一份完整的学习思维以及Android开发知识大全PDF。

当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

我这里整理了一份完整的学习思维以及Android开发知识大全PDF。

[外链图片转存中...(img-tXM3SxdZ-1712291998153)]

当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
相关推荐
...:...:...6 分钟前
Linux 第三次脚本作业
linux·运维·服务器
菜菜小蒙1 小时前
【Linux】基于UDP/TCP服务器与客户端的实现
linux·服务器·udp
web2u1 小时前
Docker入门及基本概念
java·运维·服务器·spring·docker·容器
元气满满的热码式2 小时前
Docker实战-使用docker compose搭建博客
运维·docker·容器
Anna_Tong3 小时前
阿里云如何协助解决操作系统兼容性问题
linux·服务器·ubuntu·阿里云·centos·云计算·系统迁移
HaoHao_0103 小时前
如何将MySQL数据库迁移至阿里云
服务器·数据库·阿里云·云计算·云服务器·迁移
不良人天码星3 小时前
Linux的基础指令和环境部署,项目部署实战(下)
linux·运维·服务器
火一线4 小时前
【ASP .NET Core】ASP .NET Core介绍
服务器·游戏·.netcore
EasyNVR4 小时前
基于WebRTC与AI大模型接入EasyRTC:打造轻量级、高实时、强互动的嵌入式音视频解决方案
运维·服务器·微信·小程序·webrtc·p2p·智能硬件
技术小齐5 小时前
网络运维学习笔记 022 HCIA-Datacom新增知识点03园区网典型组网架构及案例实战
运维·网络·学习