Socket.IO是一个完全由JavaScript实现、基于Node.js、支持webSocket的协议用于实时通信、跨平台的开源框架,它包括了客户端的JavaScript和服务器端的Node.js。
该种官方介绍看起来有点懵逼,简而言之就是:
- 客户端可通过Socket.IO与服务器建立实时通信管道
该下就是介绍Socket.IO通信管道的铺设、通信以及销毁工作。
- compile 'io.socket:socket.io-client:0.8.3'
服务器地址(该地址为Socket.IO官方测试地址,实际项目中请更换):
- String CHAT_SERVER_URL = "https://socketio-chat.now.sh/"
根据服务器地址,实例化Socket对象:
- Socket mSocket = IO.socket(CHAT_SERVER_URL, options);
其中options是可供用户选择的一些配置参数,部分配置如下:
- public static class Options extends io.socket.engineio.client.Socket.Options {
- // 是否自动重连
- public boolean reconnection = true;
- // 重连尝试次数
- public int reconnectionAttempts;
- // 重连间隔
- public long reconnectionDelay;
- // 最大连接等待时间
- public long reconnectionDelayMax;
- // 连接超时时间 (ms),设置为-1表示不超时
- public long timeout = 20000;
- }
在这里我们就需要注册一些监听事件,用来监听Socket通信过程中产生的一些行为,比如以下是注册Socket连接成功后的监听回调:
- Emitter.Listener connectListener;
- connectListener = new Emitter.Listener() {
- @Override
- public void call(Object... args) {
- }
- };
- socket.on(Socket.EVENT_CONNECT, connectListener);
至此,我们的管道铺设工作就已经完成了,接下来我们只需要打开管道的开关,那么客户端与服务器之间就可以互通互信:
- mSocket.connect();
那我们要如何知道两者之间是否已经连接成功了呢?没错,在2.3 我们注册过监听,一旦Socket连接成功,就会触发该回调,此时我们就可以根据项目的实际需求来做相应的处理了。
此时,如果我们要向服务器发送消息,要怎么实现呢?Socket.IO提供了如下操作:
- mSocket.emit("new message", content);
还可以这样:
- mSocket.emit("new message", content, new Ack() {
- @Override
- public void call(Object... args) {
- }
- });
当我们不想再使用管道的时候,就需要把管道给销毁,很简单,我们只需要断开连接以及注销监听即可:
- mSocket.disconnect();
- mSocket.off(Socket.EVENT_CONNECT, connectListener);
好啦,Socket.IO整个通信过程就完成啦,于我们而言,是不是简单易用。
不知该部分是不是众望所归(哈哈~),该份源码是基于Socket.IO官方的服务器地址结合实际项目融合而成,扩展性极强,特分享出来,供各位参考。
基于Socket.IO实现Android聊天功能
最后,感谢你的到来,恭喜你,坚持到了最后,该文和源码若有不当之处,请予以斧正。
来源: https://juejin.im/post/5a055ad951882554b837035e