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 同步数据。具体交互如下图所示,本文主要是关于这些新增交互或接口的笔记,广播和点对点通信请参考文章二。

image


服务器端


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


欢迎来撩

frendy

It will shine for us...