Hello Flask Socket.IO [5]

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

内容简介: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);
		...
	}
};

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

查看所有标签

猜你喜欢:

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

Ajax与PHP Web开发

Ajax与PHP Web开发

达里 / 王德民、王新颖、刘昕 / 人民邮电出版社 / 2007-4 / 39.00元

本书指导读者使用Ajax、PHP及其他相关技术建立快速响应的网页。本书不仅从Ajax的客户端和服务器端技术两个方面指导读者逐步掌握Ajax基础应用,还通过实例详细演示了Ajax表单验证、Ajax聊天室、Ajax Suggest、使用SVG实现的Ajax实时绘图程序、Ajax Grid、Ajax RSS阅读器和Ajax拖放等的实现过程。同时还介绍了在Windows和UNIX系统下的应用程序环境配置和......一起来看看 《Ajax与PHP Web开发》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

MD5 加密
MD5 加密

MD5 加密工具

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

HSV CMYK互换工具