Hello Flask Socket.IO [5]

栏目: 后端 · 发布时间: 7年前

内容简介:Hello Flask Socket.IO [5]

Hello Flask Socket.IO 系列文章五。本文基于前面的 Demo 搭建简单的推送 Socket 服务,完成服务器端和 Android 端的交互。

相关文章:

Hello Flask Socket.IO [1] Hello Flask Socket.IO [2] Hello Flask Socket.IO [3] Hello Flask Socket.IO [4] 相关 Github 源码 版权声明:本文为 frendy 原创文章,可以随意转载,但请务必在明确位置注明出处。

本文基于文章二 Hello Flask Socket.IO [2] 的广播和点对点通信来实现推送。指导思想是少即是多,只搭建 Socket 服务,用于 Server 端和用户 Client 端之间的通信转发。

对于推送 Socket 服务而言,根据业务需求,需要完善注册交互,添加反馈交互。另外也需要添加一个提供给 Server 端的消息发送接口,并通过 Server 提供的 ICE 接口向 Server 同步数据。具体交互如下图所示,本文主要是关于这些新增交互或接口的笔记,广播和点对点通信请参考文章二。

Hello Flask Socket.IO [5]

服务器端

1. 完善注册交互

@socketio.on('register')
def do_register(message):
	print('uid=%s' % (message['data']))
	emit('_register', {'token': get_token(message['data'])})
	# 调用 Server ICE 接口同步数据即可

2. 添加反馈交互

@socketio.on('report')
def do_report(message):
	print(message['status'])
	# 调用 Server ICE 接口同步数据即可

3. 添加消息发送接口

@app.route('/message', methods=['POST'])
def send_message():
	data = request.data
	print(data)
	# 广播或点对点发送消息即可
	return "OK"

20170523 - 批注:这里有安全问题,对后台对用户用了同个端口。解决办法的话,对后台或者用 ICE 接口来替换,或者用 namespace 来区分

Android 前端

1. 修改注册交互

//注册请求的回调监听
mSocket.on("_register", onRegister);

//向服务器端发送注册请求
mSocket.emit("register", data);

private Emitter.Listener onRegister = new Emitter.Listener() {
	@Override
	public void call(final Object... args) {
		...
		JSONObject data = (JSONObject) args[0];
		TOKEN = data.getString("token");
		mISocket.onRegistered(TOKEN);
		//注册点对点接收监听器,以便实现点对点消息发送
		Handler mainHandler = new Handler(Looper.getMainLooper());
		mainHandler.post(new Runnable() {
			@Override
			public void run() {
				mSocket.on(TOKEN, onP2PMessage);
			}
		});
		...
	}
};

2. 添加反馈交互

private Emitter.Listener onBroadcast = new Emitter.Listener() {
	@Override
	public void call(final Object... args) {
		...
		mISocket.onMessage(data.getString("data"));
		mSocket.emit("reporter", status);
		...
	}
};

private Emitter.Listener onP2PMessage = new Emitter.Listener() {
	@Override
	public void call(final Object... args) {
		...
		mISocket.onMessage(data.getString("data"));
		mSocket.emit("reporter", status);
		...
	}
};

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS基础教程

CSS基础教程

Simon Collison / 刘志忠 等 / 人民邮电出版社 / 2007 / 49.00元

《CSS 基础教程》是优秀的CSS 入门书,重点讲述了如何使用CSS 实现基于Web 标准的网站开发,实现网站内容和表现相分离。《CSS 基础教程》包括两部分。第一部分介绍了CSS 的基础知识和基本概念,再利用CSS 分别对网页创建中的一些基本元素加上样式,包括:文本、图像、列表、链接、表格、表单等。第二部分主要讨论了基于CSS 来实现网页基本布局的相关概念与技术,包括浮动、流体布局等。《CSS ......一起来看看 《CSS基础教程》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

html转js在线工具
html转js在线工具

html转js在线工具