前驱知识

WebSocket

维基百科:
WebSocket是一种在单个TCP连接上进行全双工通信的协议。WebSocket通信协议于2011年被IETF定为标准RFC 6455,并由RFC7936补充规范。WebSocket API也被W3C定为标准。

WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。

添加maven依赖

    <build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><configuration><source>8</source><target>8</target></configuration></plugin></plugins></build><dependencies><dependency><groupId>io.netty</groupId><artifactId>netty-all</artifactId><version>4.1.25.Final</version></dependency></dependencies>

编写代码

Chat处理器

import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.SimpleChannelInboundHandler;
import io.netty.channel.group.ChannelGroup;
import io.netty.channel.group.DefaultChannelGroup;
import io.netty.handler.codec.http.websocketx.TextWebSocketFrame;
import io.netty.util.concurrent.GlobalEventExecutor;import java.time.LocalDateTime;/*** @author: Tu9ohost* 处理消息的handler* TextWebSocketFrame: 在netty中,是用于为websocket专门处理文本的对象,frame是消息的载体*/
public class ChatHandler extends SimpleChannelInboundHandler<TextWebSocketFrame> {// 用于记录和管理所有客户端的channleprivate static ChannelGroup clients =new DefaultChannelGroup(GlobalEventExecutor.INSTANCE);@Overrideprotected void channelRead0(ChannelHandlerContext ctx, TextWebSocketFrame msg)throws Exception {// 获取客户端传输过来的消息String content = msg.text();System.out.println("接受到的数据:" + content);//      for (Channel channel: clients) {
//          channel.writeAndFlush(
//              new TextWebSocketFrame(
//                      "[服务器在]" + LocalDateTime.now()
//                      + "接受到消息, 消息为:" + content));
//      }// 下面这个方法,和上面的for循环,一致clients.writeAndFlush(new TextWebSocketFrame("[服务器在]" + LocalDateTime.now()+ "接受到消息, 消息为:" + content));}/*** 当客户端连接服务端之后(打开连接)* 获取客户端的channle,并且放到ChannelGroup中去进行管理*/@Overridepublic void handlerAdded(ChannelHandlerContext ctx) throws Exception {clients.add(ctx.channel());}@Overridepublic void handlerRemoved(ChannelHandlerContext ctx) throws Exception {// 当触发handlerRemoved,ChannelGroup会自动移除对应客户端的channel
//      clients.remove(ctx.channel());System.out.println("客户端断开,channle对应的长id为:"+ ctx.channel().id().asLongText());System.out.println("客户端断开,channle对应的短id为:"+ ctx.channel().id().asShortText());}
}

编写服务初始化

import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelPipeline;
import io.netty.channel.socket.SocketChannel;
import io.netty.handler.codec.http.HttpObjectAggregator;
import io.netty.handler.codec.http.HttpServerCodec;
import io.netty.handler.codec.http.websocketx.WebSocketServerProtocolHandler;
import io.netty.handler.stream.ChunkedWriteHandler;/*** @author: Tu9ohost*/
public class WSServerInitiazer extends ChannelInitializer<SocketChannel> {@Overrideprotected void initChannel(SocketChannel ch) throws Exception {ChannelPipeline pipeline = ch.pipeline();// websocket 基于http协议,所以要有http编解码器pipeline.addLast(new HttpServerCodec());// 对写大数据流的支持pipeline.addLast(new ChunkedWriteHandler());// 对httpMessage进行聚合,聚合成FullHttpRequest或FullHttpResponse// 几乎在netty中的编程,都会使用到此hanlerpipeline.addLast(new HttpObjectAggregator(1024*64));// ====================== 以上是用于支持http协议    ======================// ====================== 以下是支持httpWebsocket ======================/*** websocket 服务器处理的协议,用于指定给客户端连接访问的路由 : /ws* 本handler会帮你处理一些繁重的复杂的事* 会帮你处理握手动作: handshaking(close, ping, pong) ping + pong = 心跳* 对于websocket来讲,都是以frames进行传输的,不同的数据类型对应的frames也不同*/pipeline.addLast(new WebSocketServerProtocolHandler("/ws"));// 自定义的handlerpipeline.addLast(new ChatHandler());}
}

主方法

import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.nio.NioServerSocketChannel;/*** @author: Tu9ohost*/
public class WSServer {public static void main(String[] args) throws Exception {EventLoopGroup mainGroup = new NioEventLoopGroup();EventLoopGroup subGroup = new NioEventLoopGroup();try {ServerBootstrap server = new ServerBootstrap();server.group(mainGroup, subGroup).channel(NioServerSocketChannel.class).childHandler(new WSServerInitiazer());// 定义了端口为8088ChannelFuture future = server.bind(8088).sync();future.channel().closeFuture().sync();} finally {mainGroup.shutdownGracefully();subGroup.shutdownGracefully();}}
}

编写界面

<!DOCTYPE html>
<html><head><meta charset="utf-8" /><title></title></head><body><div>发送消息:</div><input type="text" id="msgContent"/><input type="button" value="点我发送" onclick="CHAT.chat()"/><div>接受消息:</div><div id="receiveMsg" style="background-color: gainsboro;"></div><script type="application/javascript">window.CHAT = {socket: null,init: function() {if (window.WebSocket) {CHAT.socket = new WebSocket("ws://127.0.0.1:8088/ws");CHAT.socket.onopen = function() {console.log("连接建立成功...");},CHAT.socket.onclose = function() {console.log("连接关闭...");},CHAT.socket.onerror = function() {console.log("发生错误...");},CHAT.socket.onmessage = function(e) {console.log("接受到消息:" + e.data);var receiveMsg = document.getElementById("receiveMsg");var html = receiveMsg.innerHTML;receiveMsg.innerHTML = html + "<br/>" + e.data;}} else {alert("浏览器不支持websocket协议...");}},chat: function() {var msg = document.getElementById("msgContent");CHAT.socket.send(msg.value);}};CHAT.init();</script></body>
</html>

检验

首先运行主方法,再打开界面,按F12,会显式链接建立成功

随意编写,再点击点我发送

服务端显式

关闭界面窗口,则会显式断开链接id

转载于:https://www.cnblogs.com/Tu9oh0st/p/10634385.html

使用netty编写IM通信界面相关推荐

  1. 为什么选择Netty作为基础通信组件?

    以下内容根据网上资料和自己整理总结而成 一.什么是Netty? Netty是一个高性能 事件驱动.异步非堵塞的IO(NIO)Java开源框架,Jboss提供,用于建立TCP等底层的连接,基于Netty ...

  2. 【转】Qt编写串口通信程序全程图文讲解

    Qt编写串口通信程序全程图文讲解 本文章原创于www.yafeilinux.com 转载请注明出处. (说明:我们的编程环境是windows xp下,在Qt Creator中进行,如果在Linux下或 ...

  3. 如何编写数据库可视化界面_编写用于数据可视化的替代文本

    如何编写数据库可视化界面 什么是替代文字 (What is Alt Text) Alt text (sometimes called Alt tags or alternative text) are ...

  4. python写前端图形界面_如何Tkinter模块编写Python图形界面

    一.为何使用Tkinter而非PyQt 众所周知,在Python中创建图形界面程序有很多种的选择,其中PyQt和wxPython都是很热门的模块包,这些第三方的图形界面模块功能强大.配置丰富,界面美观 ...

  5. label qt 自动换行_QT编写一个登录界面

    前言 继上篇:一起学Qt之基础篇---入门 今天上手实操用QT编写一个登录界面~ 系统权限这个词大家肯定不陌生,你进入一个网站也是,如果不登录,就是以游客的身份进去的,要想看到某些信息肯定需要进行登录 ...

  6. 利用Delphi编写Socket通信程序

    一.Delphi与Socket计算机网络是由一系列网络通信协议组成的,其中的核心协议是传输层的TCP/IP和UDP协议.TCP是面向连接的,通信双方保持一条通路,好比目前的电话线,使用telnet登陆 ...

  7. 一步步展示如何用C#和ACCESS编写一个登录界面

    ** 登录界面简易教程 ** 前段时间老师要求做一个登录界面来熟悉C#的操作,于是在看了很多文章后终于编出一个小程序.为了让以后入门的新手不用再找一大堆的文章来慢慢摸索,现在决定分享一下我的编写过程, ...

  8. Netty编写客户端

    Netty编写客户端 ​ 上一篇博客讲了一下解码器,但是其实没有涉及到客户端的编写,今天补上这篇博客.同时深入了解一下Netty(对于我来说).加深自己的印象. ​ 上面是一个简单的服务端的例子,之前 ...

  9. 【linux下用C语言编写带图形界面的成绩管理系统附带源代码】

    linux下用C语言编写带图形界面的成绩管理系统附带源代码:(下面内容请配合源代码看) 源代码下载地址:         点击打开链接 或留下联系方式,发给你 一.题目内容 嵌入式Linux数据库编程 ...

最新文章

  1. 配置Open***使用User/Pass方式验证登录
  2. 【Andorid X 项目笔记】动态设置ViewPager的Adapter问题(2)
  3. Oracle 10g OCP 042 题库 1-30 题 共168题
  4. 【微信网页版】给所有微信群发消息
  5. 动感英语笔记_【共同战“疫”】(一)滨海新区大港西苑小学英语教师团队
  6. SAP Commerce(SAP Hybris)学习资料汇总
  7. iOS开发小技巧--学会包装控件(有些view的位置由于代码或系统原因,位置或者尺寸不容易修改或者容易受外界影响)...
  8. 一文尽览 ECCV 2020 旷视研究院15篇论文
  9. mysql中连接和断开数据库_robot framework——连接和断开mysql数据库
  10. 对称加密算法和非对称加密算法介绍
  11. 遇到一个不得其解的问题。
  12. Unity3D(二)游戏对象及组件
  13. php与mysql事物处理
  14. 【数学建模】CUMCM-2009B 眼科病床的合理安排 解题思路整理
  15. 贝叶斯网络与EM算法
  16. 机器学习第四章之逻辑回归模型
  17. PMP/高项 项目管理培训大纲
  18. 微信小程序图片(头像)裁剪工具we-cropper含2d版-完整版
  19. win10配置Java环境
  20. Java8函数式编程、Stream流、Option的使用,一篇足够了

热门文章

  1. 汇编 cmp_ARM汇编语言入门(二)
  2. c语言邻接表的构建_c语言数据结构--图的邻接矩阵和邻接表操作的基本操作
  3. php7可以做什么开发,php7 图形用户界面GUI 开发怎么做?看完这个代码你就明白了...
  4. 字节跳动内部学习资料泄露!kafka入门教程
  5. 一个星期+4轮面试终拿下offer,进阶学习
  6. 机器学习(MACHINE LEARNING)MATLAB三层神经网络的简单应用
  7. python【力扣LeetCode算法题库】面试题 17.16- 按摩师(DP)
  8. python【蓝桥杯vip练习题库】ADV-186排列式
  9. 优秀的词云展示第三方库——wordcloud
  10. python scrapy框架原理_Scrapy框架的工作原理是什么?