基于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

相关文章
|
5月前
|
存储 前端开发 Java
【JAVA】Java 项目实战之 Java Web 在线商城项目开发实战指南
本文介绍基于Java Web的在线商城技术方案与实现,涵盖三层架构设计、MySQL数据库建模及核心功能开发。通过Spring MVC + MyBatis + Thymeleaf实现商品展示、购物车等模块,提供完整代码示例,助力掌握Java Web项目实战技能。(238字)
649 0
|
4月前
|
安全 前端开发 Java
《深入理解Spring》:现代Java开发的核心框架
Spring自2003年诞生以来,已成为Java企业级开发的基石,凭借IoC、AOP、声明式编程等核心特性,极大简化了开发复杂度。本系列将深入解析Spring框架核心原理及Spring Boot、Cloud、Security等生态组件,助力开发者构建高效、可扩展的应用体系。(238字)
|
7月前
|
人工智能 前端开发 Java
2025年WebStorm高效Java开发全指南:从配置到实战
WebStorm 2025不仅是一款强大的JavaScript IDE,也全面支持Java开发。本文详解其AI辅助编程、Java特性增强及性能优化,并提供环境配置、高效开发技巧与实战案例,助你打造流畅的全栈开发体验。
642 4
|
7月前
|
安全 Java 领域建模
Java 17 探秘:不容错过的现代开发利器
Java 17 探秘:不容错过的现代开发利器
483 0
|
5月前
|
存储 JavaScript 安全
Web渗透-XSS漏洞深入及xss-labs靶场实战
XSS(跨站脚本攻击)是常见的Web安全漏洞,通过在网页中注入恶意脚本,窃取用户信息或执行非法操作。本文介绍其原理、分类(反射型、存储型、DOM型)、测试方法及xss-labs靶场实战案例,帮助理解与防御XSS攻击。
1814 1
Web渗透-XSS漏洞深入及xss-labs靶场实战
|
5月前
|
消息中间件 人工智能 Java
抖音微信爆款小游戏大全:免费休闲/竞技/益智/PHP+Java全筏开源开发
本文基于2025年最新行业数据,深入解析抖音/微信爆款小游戏的开发逻辑,重点讲解PHP+Java双引擎架构实战,涵盖技术选型、架构设计、性能优化与开源生态,提供完整开源工具链,助力开发者从理论到落地打造高留存、高并发的小游戏产品。
|
5月前
|
安全 Linux PHP
Web渗透-命令执行漏洞-及常见靶场检测实战
命令执行漏洞(RCE)指应用程序调用系统命令时,用户可控制输入参数,导致恶意命令被拼接执行,从而危害系统安全。常见于PHP的system、exec等函数。攻击者可通过命令连接符在目标系统上执行任意命令,造成数据泄露或服务瘫痪。漏洞成因包括代码层过滤不严、第三方组件缺陷等。可通过参数过滤、最小权限运行等方式防御。本文还介绍了绕过方式、靶场测试及复现过程。
1334 0
|
5月前
|
存储 Java 关系型数据库
Java 项目实战基于面向对象思想的汽车租赁系统开发实例 汽车租赁系统 Java 面向对象项目实战
本文介绍基于Java面向对象编程的汽车租赁系统技术方案与应用实例,涵盖系统功能需求分析、类设计、数据库设计及具体代码实现,帮助开发者掌握Java在实际项目中的应用。
236 0
|
6月前
|
JavaScript 安全 前端开发
Java开发:最新技术驱动的病人挂号系统实操指南与全流程操作技巧汇总
本文介绍基于Spring Boot 3.x、Vue 3等最新技术构建现代化病人挂号系统,涵盖技术选型、核心功能实现与部署方案,助力开发者快速搭建高效、安全的医疗挂号平台。
340 3