由于工作当中需要用的flask_socketio,所以自己学习了一下如何使用,查阅了有关文档,当看到回调函数callback的时候,发现文档里都描述的不太清楚,最后终于琢磨出来了,分享给有需要的朋友

首先看看官方文档及其译文

看到这里以后,我就开始照着文档敲代码,发现即使我按照文档里的写法写了,也没有调用我们的回调函数ack

废话不多说,直接上最终版代码

index.html

<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8">
<title>index1</title>
<script type="text/javascript" src="//cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
<script type="text/javascript" src="//cdn.bootcss.com/socket.io/1.5.1/socket.io.min.js"></script> <script type="text/javascript" charset="utf-8"> $(document).ready(function () {
var socket = io.connect('http://127.0.0.1:8000/'); socket.on('connect', function () {
socket.emit('connect_event', {data: 'client,connected!'}); //客户端向服务端发起请求链接
}); socket.on('server_response', function (msg, ack) {
$('#log').append('<br>' + $('<div/>').text('Received #' + ': ' + msg.data).html()); //将服务端发过来的信息,显示在页面上
ack('client received'); //响应服务端的回调函数,告知服务端,客户端已收到消息 }); socket.on('server_response1', function (msg) {
$('#log').append('<br>' + $('<div/>').text('Received #' + ': ' + msg.data).html()); //将服务端发过来的信息,显示在页面上
// ack('msg'); //响应服务端的回调函数,告知服务端,客户端已收到消息 }); $('#aa').click(function (event) {
socket.emit('client_event', {data: $('#emit_data').val()}, function (data) {
console.log("server received data", data); // 此处data为服务端发送过来的回调参数,说明服务端已收到客户端的消息; });
}); }); </script> </head>
<body>
<h2>WebSokect</h2>
<form id="emit" method="POST" action='#'>
<input type="text" name="emit_data" id="emit_data" placeholder="Message">
<input type="button" value="Echo" id="aa">
</form>
<div id='log'></div>
</body>
</html>

socket1.py

# -*- coding: utf-8 -*-
from flask import Flask, render_template
from flask_socketio import SocketIO, emit app = Flask(__name__, template_folder='./')
socketio = SocketIO()
socketio.init_app(app) def ack(data): # 服务端回调函数
print u'客户端已收到消息,回调参数为',data # 服务端回调函数的参数 @app.route('/')
def index():
return render_template('index.html') @socketio.on('client_event')
def client_msg(msg):
print msg
emit('server_response', {'data': msg['data']}, callback=ack) # 指定服务端回调函数为ack,参数由客户端指定
return 'server received data!' # 客户端回调函数的参数 @socketio.on('connect_event')
def connected_msg(msg):
print u'客户端建立请求,信息为:',msg['data']
emit('server_response1', {'data': msg['data']}) if __name__ == '__main__':
socketio.run(app, debug=True, host='0.0.0.0', port=8000)

其实,我想说的已经全部放在了注释里了,

总结一下,在测试中遇到的问题吧

服务端:在emit中,指定callback,

客户端:在socket.on的function里,有两个参数

    第一个参数,是用来接收服务端return

    如果我们只写一个就是监听server_response里的信息,这个参数msg就代表收到的信息

    当我们指定了第二个参数时(可以不和服务端的回调函数ack同名),这个参数就是

on用来监听对应通道,emit向对应通道发送消息

socket.on中,第一个参数为通道的名字,第二个参数为一个函数function

  function中,可以有两个参数,第一个参数是用来接收服务端return的值,第二个参数是回调函数名(随便取)

  如果服务端在emit中指定了callback,就比如上图,如果希望客户端收到消息后给服务端回传一个消息,触发服务端的callback即ack函数,则这第二个参数必须指定,否则不会触发

  如果在服务端没有指定callback,但是在客户端指定了第二个参数,则在页面上会报错,如下图

必须对应好,才不会出错

解决有关flask-socketio中服务端和客户端回调函数callback参数的问题(全网最全)的更多相关文章

  1. 使用flask_socketio实现服务端向客户端定时推送

    websocket连接是客户端与服务器之间永久的双向通信通道,直到某方断开连接. 双向通道意味着在连接时,服务端随时可以发送消息给客户端,反之亦然,这在一些需要即时通讯的场景比如多人聊天室非常重要. ...

  2. Netty 学习(二):服务端与客户端通信

    Netty 学习(二):服务端与客户端通信 作者: Grey 原文地址: 博客园:Netty 学习(二):服务端与客户端通信 CSDN:Netty 学习(二):服务端与客户端通信 说明 Netty 中 ...

  3. app开发中如何利用sessionId来实现服务端与客户端保持回话

    app开发中如何利用sessionId来实现服务端与客户端保持回话 这个问题太过于常见,也过于简单,以至于大部分开发者根本没有关注过这个问题,我根据和我沟通的开发者中,总结出来常用的方法有以下几种: ...

  4. 常量,字段,构造方法 调试 ms 源代码 一个C#二维码图片识别的Demo 近期ASP.NET问题汇总及对应的解决办法 c# chart控件柱状图,改变柱子宽度 使用C#创建Windows服务 C#服务端判断客户端socket是否已断开的方法 线程 线程池 Task .NET 单元测试的利剑——模拟框架Moq

    常量,字段,构造方法   常量 1.什么是常量 ​ 常量是值从不变化的符号,在编译之前值就必须确定.编译后,常量值会保存到程序集元数据中.所以,常量必须是编译器识别的基元类型的常量,如:Boolean ...

  5. (转)客户端触发Asp.net中服务端控件事件

    第一章. Asp.net中服务端控件事件是如何触发的 Asp.net 中在客户端触发服务端事件分为两种情况: 一. WebControls中的Button 和HtmlControls中的Type为su ...

  6. seata服务端和客户端配置(使用nacos进行注册发现,使用mysql进行数据持久化),以及过程中可能会出现的问题与解决方案

    seata服务端和客户端配置(使用nacos进行注册发现,使用mysql进行数据持久化),以及过程中可能会出现的问题与解决方案 说明: 之所以只用nacos进行了注册与发现,因为seata使用naco ...

  7. (转)SVN 服务端、客户端安装及配置、导入导出项目

    SVN服务器搭建和使用(一) Subversion是优秀的版本控制工具,其具体的的优点和详细介绍,这里就不再多说. 首先来下载和搭建SVN服务器. 现在Subversion已经迁移到apache网站上 ...

  8. 【转】TCP/UDP简易通信框架源码,支持轻松管理多个TCP服务端(客户端)、UDP客户端

    [转]TCP/UDP简易通信框架源码,支持轻松管理多个TCP服务端(客户端).UDP客户端 目录 说明 TCP/UDP通信主要结构 管理多个Socket的解决方案 框架中TCP部分的使用 框架中UDP ...

  9. openssl实现双向认证教程(服务端代码+客户端代码+证书生成)

    一.背景说明 1.1 面临问题 最近一份产品检测报告建议使用基于pki的认证方式,由于产品已实现https,商量之下认为其意思是使用双向认证以处理中间人形式攻击. <信息安全工程>中接触过 ...

随机推荐

  1. http的CA证书安装(也就是https)

    近几年随着安全意识的提高,https流行起来,很多小伙伴不太了解https是什么,其实http和https并没有区别,简单的来说,https就是将http通信进行了加密和解密的一个过程.加上谷歌浏览器 ...

  2. dubbo服务简单搭建

    一.初识dubbo: 架构图: Provider: 暴露服务的服务提供方. Consumer: 调用远程服务的服务消费方. Registry: 服务注册与发现的注册中心. Monitor: 统计服务的 ...

  3. [Java] JDK 环境配置(图文)

    Windows10 上的安装配置 1.前往 JDK 官网下载对应 jdk 版本安装包: http://www.oracle.com/technetwork/java/javase/downloads/ ...

  4. node.js与比特币(typescript实现)

    BTC中的utxo模型 BTC中引入了许多创新的概念与技术,区块链.PoW共识.RSA加密.萌芽阶段的智能合约等名词是经常被圈内人所提及,诚然这些创新的实现使得BTC变成了一种有可靠性和安全性保证的封 ...

  5. TOJ 1214: 数据结构练习题――线性表操作

    描述 请你定义一个线性表,可以对表进行"在某个位置之前插入一个元素"."删除某个位置的元素"."清除所有元素"."获取某个位置的元 ...

  6. Kettle 初始配置数据量类型资源库

    PS:有段时间不使用Kettle了,但总遇到小伙伴问起,写一篇记录下. 文档使用版本:KETTLE 7.0 Kettle资源库可分为文件与数据库,文件型只需要配置好存放路径就行,这边介绍的是配置数据库 ...

  7. 第一次作业:来自一个奋斗的IT学子

    第一部分 结缘计算机 1.1你为什么选择计算机专业?你认为你的条件如何?和这些博主比呢?(必答) 说起为何结缘了计算机,就得谈谈专业报考了,我觉得我的报考真是一个反面教科书了.由于高中以前每天只要想着 ...

  8. python的测试

    测试 知识点 单元测试概念 使用 unittest 模块 测试用例的编写 异常测试 测试覆盖率概念 使用 coverage 模块 实验步骤 1. 应该测试什么? 如果可能的话,代码库中的所有代码都要测 ...

  9. 手把手教你 LabVIEW 串口仪器控制——VISA 驱动下载安装篇

           仪器控制,核心在于 VISA 函数..有些仪器可能不需要 VISA,有自己的 DLL 什么的,我就管不着.        正常情况下,大家安装的 LabVIEW,都是不带 VISA 驱动 ...

  10. 动手写IL到Lua的翻译器——准备

    文章里的代码粘过来的时候格式有点问题,原因是一开始文章是在订阅号上写的(gamedev101,文末有二维码),不知道为啥贴过来就没了格式,还要手动删行号,就没搞了. 介绍下问题背景: 小说君正在参与的 ...