基于Netty的WEB聊天服务端开发|Java 开发实战

简介: 基于Netty的WEB聊天服务端开发|Java 开发实战

1.主要采用了Netty的什么功能



webSocket的wss    
复制代码


//wss配置
@Override
public void initChannel(SocketChannel ch) throws Exception {
  ChannelPipeline pipeline = ch.pipeline();
  pipeline.addLast(new IdleStateHandler(10, 0, 0, TimeUnit.SECONDS));
  pipeline.addLast(new HttpServerCodec());
  pipeline.addLast(new HttpObjectAggregator(1024 * 1024));
  pipeline.addLast(new ChunkedWriteHandler());
  // pipeline.addLast(new HttpRequestHandler("/ws"));
  pipeline.addLast(new WebSocketServerProtocolHandler("/ws", null, true, 1024 * 512));
  // pipeline.addLast(new HeartbeatServerHandler());
  pipeline.addLast(new TextWebSocketFrameHandler());
  // 配置ssl访问的
  logger.info(WebsocketChatServerInitializer.class.getResource("/").toString());
  URL xmlpath = this.getClass().getClassLoader().getResource("");
  logger.info(xmlpath.toString());
  // File f = new File(this.getClass().getResource("/").getPath());
  File f = new File(WebsocketChatServerInitializer.class.getResource("").toString());
  logger.info(f.getAbsolutePath());
  SSLContext sslContext = SslUtil.createSSLContext("PKCS12",
        this.getClass().getClassLoader().getResourceAsStream("keystore.p12"), "changeit"); 
       SSLEngine engine =sslContext.createSSLEngine();
  SSLEngine sslEngine = sslContext.createSSLEngine();
  sslEngine.setNeedClientAuth(false);
  sslEngine.setUseClientMode(false);
  pipeline.addFirst(new SslHandler(sslEngine));
    }
复制代码


2.WEB聊天的基本流程和一些限制



2.1消息采用wss发送
  2.2首先前端用户先在服务端登录,获取token,然后连接websocket绑定服务端.
     为了防止恶意连接保存token的时候时候key为:前缀_用户名
  2.3服务端校验token后会保存一个键值对,用户名:Channel
     为了防止恶意信息的发送,在发送消息的时候会根据用户名获取Channel,然后当前的Channel和获取到的Channel可以做个比对,这样用户就是正常用户了
  2.4web端绑定了服务端后可以进行消息的收发,消息格式为JSON
     Netty服务端主要通过保存的Channel获取连接,然后做信息转发推送
  2.5配置个后台管理的模块,对用户进行强制管理,后消息广播
复制代码


3.消息格式



整体格式
{
    "cmd":null,
    "mdChild":ull,
    "from":null,
    "accept":null,
    "group":null,
    "msg":null,
    "status":null,
    "id":null,
    "createDate":"2021-01-09 22:26:14",
    "chatSet":null,
    "groupSet":null,
    "oldMsg":null
}
单聊
{
    "cmd":"3",
    "from":{
        "userCode":"dnmt"
    },
    "accept":{
        "userCode":"fhx"
    },
    "msg":"单聊测试"
}
群聊
{
    "cmd":"4",
    "from":{
        "userCode":"dnmt"
    },
    "group":{
        "groupCode":"g003"
    },
    "msg":"群聊测试"
}
复制代码


4服务端的扩展



3.1因为当用户量变大,服务端可能处理有些跟不上。
     这里可以采用的是服务端集群部署。
  3.2集群部署问题
     消息的转发可能会跨服务器进行推送?
     用户的跨服务器绑定?
  3.3netty集群解决跨服务器消息推送思路
     采用redis的发布和订阅进行消息的转发,当前获取订阅消息判断用户是否存在,如果存在就进行消息处理。
 3.4用户的跨服务器绑定。
     这里用到了zookeeper
     当服务器启动的时候,会把服务器的连接信息发送到zookeeper上
     当用户登录的时候,可以根据一个简单的负载均衡算法(随机、或者最小)获取netty服务器的绑定信息,然后绑定到后端服务器。
 3.5进一步性能提升
    服务端在处理转发消息的时候,采用线程池处理。
复制代码


5.以玩转的地方



1.支持了WEB的语音、和视频聊天
    刚开始的时候是采用了peerjs的WEBRTC方式,进行的视频聊天,但是对node不了解和感觉这样不可控,采用了下面的方式。
  2.通过WEBRTC的浏览器音频,视频录制功能,定时获取到数据,然后进行base64编码进行数据传输,转发到web端解码进行音视频聊天。
  3.在视频聊天的时候,可以借助opencv进行一些对视频的操作(这里是我开始学习opencv的地方)
    简单的例子:视频中人脸识别的思路,首先提取视频文件的音频(ffmpeg),然后对视频跳帧(主要想提高点速度)的处理获取每帧的图片,处理完毕后提取的音频和新的视频文件合并,然后编码进行视频流转发
复制代码


6.项目地址欢迎star

相关文章
|
19天前
|
SQL 缓存 自然语言处理
实战案例1:基于C语言的Web服务器实现。
实战案例1:基于C语言的Web服务器实现。
72 15
|
12天前
|
前端开发 JavaScript API
【独家揭秘】Bottle框架为何能俘获开发者的心?三大实战案例带你领略Web开发新境界!
【8月更文挑战第31天】Bottle是一款轻量级Python Web框架,以简单高效著称,秉持极简设计,适合快速开发小型项目或构建API服务。本文通过具体代码示例展示Bottle框架的独特魅力,从安装到创建应用、路由设置、模板渲染及表单处理等方面进行详细介绍,帮助读者轻松上手并掌握Bottle的应用技巧。
27 1
|
2月前
|
SQL 安全 数据库
Python Web开发者必学:SQL注入、XSS、CSRF攻击与防御实战演练!
【7月更文挑战第26天】在 Python Web 开发中, 安全性至关重要。本文聚焦 SQL 注入、XSS 和 CSRF 这三大安全威胁,提供实战防御策略。SQL 注入可通过参数化查询和 ORM 框架来防范;XSS 则需 HTML 转义用户输入与实施 CSP;CSRF 防御依赖 CSRF 令牌和双重提交 Cookie。掌握这些技巧,能有效加固 Web 应用的安全防线。安全是持续的过程,需贯穿开发始终。
64 1
Python Web开发者必学:SQL注入、XSS、CSRF攻击与防御实战演练!
|
11天前
|
Java 缓存 数据库连接
揭秘!Struts 2性能翻倍的秘诀:不可思议的优化技巧大公开
【8月更文挑战第31天】《Struts 2性能优化技巧》介绍了提升Struts 2 Web应用响应速度的关键策略,包括减少配置开销、优化Action处理、合理使用拦截器、精简标签库使用、改进数据访问方式、利用缓存机制以及浏览器与网络层面的优化。通过实施这些技巧,如懒加载配置、异步请求处理、高效数据库连接管理和启用GZIP压缩等,可显著提高应用性能,为用户提供更快的体验。性能优化需根据实际场景持续调整。
35 0
|
11天前
|
开发者 前端开发 开发框架
JSF与移动应用,开启全新交互体验!让你的Web应用轻松征服移动设备,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,移动设备的普及使得构建移动友好的应用变得至关重要。尽管JSF(JavaServer Faces)主要用于Web应用开发,但结合Bootstrap等前端框架,也能实现优秀的移动交互体验。本文探讨如何在JSF应用中实现移动友好性,并通过示例代码展示具体实现方法。使用Bootstrap的响应式布局和组件可以确保JSF页面在移动设备上自适应,并提供友好的表单输入和提交体验。尽管JSF存在组件库较小和学习成本较高等局限性,但合理利用其特性仍能显著提升用户体验。通过不断学习和实践,开发者可以更好地掌握JSF应用的移动友好性,为Web应用开发贡献力量。
19 0
|
11天前
|
API UED 开发者
如何在Uno Platform中轻松实现流畅动画效果——从基础到优化,全方位打造用户友好的动态交互体验!
【8月更文挑战第31天】在开发跨平台应用时,确保用户界面流畅且具吸引力至关重要。Uno Platform 作为多端统一的开发框架,不仅支持跨系统应用开发,还能通过优化实现流畅动画,增强用户体验。本文探讨了Uno Platform中实现流畅动画的多个方面,包括动画基础、性能优化、实践技巧及问题排查,帮助开发者掌握具体优化策略,提升应用质量与用户满意度。通过合理利用故事板、减少布局复杂性、使用硬件加速等技术,结合异步方法与预设缓存技巧,开发者能够创建美观且流畅的动画效果。
34 0
|
11天前
|
开发者 C# UED
如何轻松将WinUI控件引入Web应用?Uno Platform实战攻略——从环境搭建到性能优化,一探究竟!
【8月更文挑战第31天】Uno Platform 通过支持 WebAssembly,将 WinUI 控件无缝带入 Web,为多平台开发提供了新途径。本文介绍如何在 Web 中使用 WinUI 控件,包括环境搭建、控件使用、性能优化、样式调整及测试调优,助力开发者打造高质量跨平台应用。
29 0
|
11天前
|
前端开发 开发者 Apache
揭秘Apache Wicket项目结构:如何打造Web应用的钢铁长城,告别混乱代码!
【8月更文挑战第31天】Apache Wicket凭借其组件化设计深受Java Web开发者青睐。本文详细解析了Wicket项目结构,帮助你构建可维护的大型Web应用。通过示例展示了如何使用Maven管理依赖,并组织页面、组件及业务逻辑,确保代码清晰易懂。Wicket提供的页面继承、组件重用等功能进一步增强了项目的可维护性和扩展性。掌握这些技巧,能够显著提升开发效率,构建更稳定的Web应用。
34 0
|
11天前
|
JSON API 数据库
探索FastAPI:不仅仅是一个Python Web框架,更是助力开发者高效构建现代化RESTful API服务的神器——从环境搭建到CRUD应用实战全面解析
【8月更文挑战第31天】FastAPI 是一个基于 Python 3.6+ 类型提示标准的现代 Web 框架,以其高性能、易用性和现代化设计而备受青睐。本文通过示例介绍了 FastAPI 的优势及其在构建高效 Web 应用中的强大功能。首先,通过安装 FastAPI 和 Uvicorn 并创建简单的“Hello, World!”应用入门;接着展示了如何处理路径参数和查询参数,并利用类型提示进行数据验证和转换。
29 0