netty-socketio

一、简介

  netty-socketio是一个开源的Socket.io服务器端的一个java的实现,它基于Netty框架。项目地址为:https://github.com/mrniko/netty-socketio 。socket.io是一个跨浏览器使用websocket为实时实时应用提供服务。本例子使用maven构建,依赖如下:

<dependency>
    <groupId>com.corundumstudio.socketio</groupId>
    <artifactId>netty-socketio</artifactId>
    <version>1.6.5</version>
</dependency>

  客户端使用的是socket.io-client,下载地址为:https://github.com/Automattic/socket.io-client

二、相关代码

  服务器端:

  消息实体

 1 package com.test.socket;
 2
 3 public class ChatObject {
 4
 5     private String userName;
 6     private String message;
 7
 8     public ChatObject() {
 9     }
10
11     public ChatObject(String userName, String message) {
12         super();
13         this.userName = userName;
14         this.message = message;
15     }
16
17     public String getUserName() {
18         return userName;
19     }
20
21     public void setUserName(String userName) {
22         this.userName = userName;
23     }
24
25     public String getMessage() {
26         return message;
27     }
28
29     public void setMessage(String message) {
30         this.message = message;
31     }
32
33 }

  监听器

 1 package com.test.socket;
 2
 3 import com.corundumstudio.socketio.AckRequest;
 4 import com.corundumstudio.socketio.SocketIOClient;
 5 import com.corundumstudio.socketio.SocketIOServer;
 6 import com.corundumstudio.socketio.listener.DataListener;
 7
 8 public class CharteventListener implements DataListener<ChatObject> {
 9
10     SocketIOServer server;
11
12     public void setServer(SocketIOServer server) {
13         this.server = server;
14     }
15
16     public void onData(SocketIOClient client, ChatObject data,
17             AckRequest ackSender) throws Exception {
18         //chatevent为 事件的名称,data为发送的内容
19         this.server.getBroadcastOperations().sendEvent("chatevent", data);
20     }
21
22 }

  服务器端启动代码

 1 package com.test.socket;
 2
 3 import com.corundumstudio.socketio.Configuration;
 4 import com.corundumstudio.socketio.SocketIOServer;
 5
 6 public class SocketServer {
 7     public static void main(String[] args) throws InterruptedException {
 8
 9         Configuration config = new Configuration();
10         config.setHostname("localhost");
11         config.setPort(9092);
12
13         SocketIOServer server = new SocketIOServer(config);
14
15         CharteventListener listner = new CharteventListener();
16         listner.setServer(server);
17         //   chatevent为事件名称
18         server.addEventListener("chatevent", ChatObject.class, listner);
19         //启动服务
20         server.start();
21
22         Thread.sleep(Integer.MAX_VALUE);
23
24         server.stop();
25     }
26
27 }
28                                                 

  运行该类,服务器端即可启动

  客户端message.html代码如下:

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 2 <html>
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 5 <title>Insert title here</title>
 6 <script src="./jquery-1.9.1.js" type="text/javascript"></script>
 7 <script type="text/javascript" src="./socket.io/socket.io.js"></script>
 8     <style>
 9         body {
10             padding:20px;
11         }
12         #console {
13             height: 400px;
14             overflow: auto;
15         }
16         .username-msg {color:orange;}
17         .connect-msg {color:green;}
18         .disconnect-msg {color:red;}
19         .send-msg {color:#888}
20     </style>
21 </head>
22 <body>
23     <h1>Netty-socketio示例</h1>
24     <br/>
25     <div id="console" class="well">
26     </div>
27         <form class="well form-inline" onsubmit="return false;">
28            <input id="name" class="input-xlarge" type="text" placeholder="用户名称..."/>
29            <input id="msg" class="input-xlarge" type="text" placeholder="发送内容..."/>
30            <button type="button" onClick="sendMessage()" class="btn">Send</button>
31            <button type="button" onClick="sendDisconnect()" class="btn">Disconnect</button>
32         </form>
33 </body>
34 <script type="text/javascript">
35         var socket =  io.connect(‘http://localhost:9092‘);
36
37         socket.on(‘connect‘, function() {
38             output(‘<span class="connect-msg">Client has connected to the server!</span>‘);
39         });
40
41         socket.on(‘chatevent‘, function(data) {
42             output(‘<span class="username-msg">‘ + data.userName + ‘:</span> ‘ + data.message);
43         });
44
45         socket.on(‘disconnect‘, function() {
46             output(‘<span class="disconnect-msg">The client has disconnected!</span>‘);
47         });
48         function sendDisconnect() {
49             socket.disconnect();
50         }
51
52         function sendMessage() {
53             var userName = $("#name").val()
54             var message = $(‘#msg‘).val();
55             $(‘#msg‘).val(‘‘);
56             socket.emit(‘chatevent‘, {userName: userName, message: message});
57         }
58
59         function output(message) {
60             var currentTime = "<span class=‘time‘>" +  new Date() + "</span>";
61             var element = $("<div>" + currentTime + " " + message + "</div>");
62             $(‘#console‘).prepend(element);
63         }
64     </script>
65 </html>

  客户端需要引入jquery与socket.io.js文件。

  在浏览器打开该html文件,输入用户名称以及消息内容发送,服务器端获取到发送的内容之后,会将该消息发送会客户端,客户端接收到从服务器端返回的消息或,将该消息添加到页面并显示。运行效果如下图:

时间: 2025-01-20 05:15:34

netty-socketio的相关文章

Netty5序章之BIO NIO AIO演变

Netty5序章之BIO NIO AIO演变 Netty是一个提供异步事件驱动的网络应用框架,用以快速开发高性能.高可靠的网络服务器和客户端程序.Netty简化了网络程序的开发,是很多框架和公司都在使用的技术.更是面试的加分项.Netty并非横空出世,它是在BIO,NIO,AIO演变中的产物,是一种NIO框架.而BIO,NIO,AIO更是笔试中要考,面试中要问的技术.也是一个很好的加分项,加分就是加工资,你还在等什么?本章带你细细品味三者的不同! 流程图: 技术:BIO,NIO,AIO 说明:g

Netty(7)源码-ByteBuf

一.ByteBuf工作原理 1. ByteBuf是ByteBuffer的升级版: jdk中常用的是ByteBuffer,从功能角度上,ByteBuffer可以完全满足需要,但是有以下缺点: ByteBuffer一旦分配完成,长度固定,不能动态扩展和收缩,当需要编码的POJO对象大于分配容量时发生索引越界异常 ByteBuffer只要一个标识位置的指针postion,读写切换比较麻烦,flip rewind等操作 功能有限 ByteBuf依然是Byte数组缓冲区,拥有ByteBuffer的一切功能

下载-深入浅出Netty源码剖析、Netty实战高性能分布式RPC、NIO+Netty5各种RPC架构实战演练三部曲视频教程

下载-深入浅出Netty源码剖析.Netty实战高性能分布式RPC.NIO+Netty5各种RPC架构实战演练三部曲视频教程 第一部分:入浅出Netty源码剖析 第二部分:Netty实战高性能分布式RPC 第三部分:NIO+Netty5各种RPC架构实战演练

Netty对Protocol Buffer多协议的支持(八)

Netty对Protocol Buffer多协议的支持(八) 一.背景 在上篇博文中笔者已经用代码演示了如何在netty中使用Protocol Buffer,然而细心的用户可能会发现一个明显的不足之处就是,我们的Handler只能处理一种特定的类型,而我们的项目中又不可能只有一种类型,那么这个问题该怎么解决了?多的不说,笔者直接上代码. 二.代码实现 2.1 message的编写 syntax = "proto2"; package com.rsy.netty.protobuf; op

Java Netty (1)

Netty是由JBOSS提供的一个java开源框架,本质上也是NIO,是对NIO的封装,比NIO更加高级,可以说发展的路线是IO->NIO->Netty. ServerBootstrap和ClientBootstrap是Netty中两个比较重要的类,分别用来进行服务器和客户端的初始化. 服务器: // ChannelFactory final ChannelFactory channelFactory = new NioServerSocketChannelFactory( // Boss线程

netty 解决TCP粘包与拆包问题(二)

TCP以流的方式进行数据传输,上层应用协议为了对消息的区分,采用了以下几种方法. 1.消息固定长度 2.第一篇讲的回车换行符形式 3.以特殊字符作为消息结束符的形式 4.通过消息头中定义长度字段来标识消息的总长度 一.采用指定分割符解决粘包与拆包问题 服务端 1 package com.ming.netty.nio.stickpack; 2 3 4 5 import java.net.InetSocketAddress; 6 7 import io.netty.bootstrap.ServerB

用Netty解析Redis网络协议

用Netty解析Redis网络协议 根据Redis官方文档的介绍,学习了一下Redis网络通信协议.然后偶然在GitHub上发现了个用Netty实现的Redis服务器,很有趣,于是就动手实现了一下! 1.RESP协议 Redis的客户端与服务端采用一种叫做 RESP(REdis Serialization Protocol)的网络通信协议交换数据.RESP的设计权衡了实现简单.解析快速.人类可读这三个因素.Redis客户端通过RESP序列化整数.字符串.数据等数据类型,发送字符串数组表示参数的命

tomcat 、NIO、netty 本质

tomcat 基于 web 浏览器的通信容器 nio 同步非阻塞的I/O模型 netty 通信框架,对 nio 的封装

Netty中的那些坑

Netty中的那些坑(上篇) 最近开发了一个纯异步的redis客户端,算是比较深入的使用了一把netty.在使用过程中一边优化,一边解决各种坑.儿这些坑大部分基本上是Netty4对Netty3的改进部分引起的. 注:这里说的坑不是说netty不好,只是如果这些地方不注意,或者不去看netty的代码,就有可能掉进去了. 坑1: Netty 4的线程模型转变 在Netty 3的时候,upstream是在IO线程里执行的,而downstream是在业务线程里执行的.比如netty从网络读取一个包传递给

Netty利用ChannelGroup广播消息

在Netty中提供了ChannelGroup接口,该接口继承Set接口,因此可以通过ChannelGroup可管理服务器端所有的连接的Channel,然后对所有的连接Channel广播消息. Server端: public class BroadCastServer { public static void run(int port) { EventLoopGroup boss = new NioEventLoopGroup(); EventLoopGroup worker = new NioE