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);
		...
	}
};

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

查看所有标签

猜你喜欢:

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

Distributed Algorithms

Distributed Algorithms

Wan Fokkink / The MIT Press / 2013-12-6 / USD 40.00

This book offers students and researchers a guide to distributed algorithms that emphasizes examples and exercises rather than the intricacies of mathematical models. It avoids mathematical argumentat......一起来看看 《Distributed Algorithms》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具