我正在尝试创建一个聊天应用程序。我正在使用Flask-SocketIO和Flask-blueprints。
我的js代码是这样的:
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/1.7.3/socket.io.min.js"></script>
<script type="text/javascript">
var socket = io.connect("http://127.0.0.1:5000/aptitude/startAptitude");
console.log("connected");
socket.on("connect", function () {
socket.emit("my event", {
data: "User Connected",
});
console.log("socket is on");
var form = $("form").on("submit", function (e) {
e.preventDefault();
let user_name = $("input.username").val();
let user_input = $("input.message").val();
console.log("form data is", user_name, " ", user_input);
socket.emit("my event", {
user_name: user_name,
message: user_input,
});
console.log("socket emitted");
$("input.message").val("").focus();
});
});
socket.on("my response", function (msg) {
console.log("responese", msg);
if (typeof msg.user_name !== "undefined") {
$("h3").remove();
$("div.message_holder").append(
'<div><b style="color: #000">' +
msg.user_name +
"</b> " +
msg.message +
"</div>"
);
}
});
</script>
蓝图中的和routes.py如下:
from RecruitmentService import socketio as sc
from RecruitmentService import app
from flask_socketio import SocketIO
from flask_socketio import send, emit
mod = Blueprint('aptitude', __name__ ,template_folder='templates')
@mod.route('/getAptitudeQuestions', methods=['GET'])
def getAptiQuestions():
questionset,answerset = getQuestions()
return Response(json.dumps(questionset), status=200, mimetype='application/json')
@mod.route('/startAptitude', methods=['GET','POST'])
def startAptitude():
# return "Hello world"
print("--------------------------------------------")
print("socket is,", sc)
return render_template('session.html')
def messageReceived(methods=['GET', 'POST']):
print('message was received!!!')
@sc.on('my event')
def handle_my_custom_event(json):
print("hiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiii")
print('received my event: ' + str(json))
sc.emit('my response', "im here", callback=messageReceived)
return "yes"
运行应用程序时,我看到控制台语句为:
connected
startAptitude:30 socket is on
startAptitude:35 form data is sender chat message
startAptitude:40 socket emitted
但是事件处理程序中给出的打印语句不会在终端中打印。我不确定事件是否被触发。
终端输出是这样的:
* Restarting with stat
* Debugger is active!
* Debugger PIN: 120-320-553
(22408) wsgi starting up on http://127.0.0.1:5000
(22408) accepted ('127.0.0.1', 52027)
127.0.0.1 - - [23/Jul/2020 19:14:41] "GET /socket.io/?EIO=3&transport=polling&t=NDxwq3E HTTP/1.1" 200 349 0.001998
127.0.0.1 - - [23/Jul/2020 19:14:41] "POST /socket.io/?EIO=3&transport=polling&t=NDxwq3i&sid=021dfdd91a4e4b22bb4dcfd726465c93 HTTP/1.1" 200 219 0.001026
(22408) accepted ('127.0.0.1', 52030)
127.0.0.1 - - [23/Jul/2020 19:14:42] "GET /socket.io/?EIO=3&transport=polling&t=NDxwq4M&sid=021dfdd91a4e4b22bb4dcfd726465c93 HTTP/1.1" 200 183 0.001000
127.0.0.1 - - [23/Jul/2020 19:14:42] "GET /socket.io/?EIO=3&transport=polling&t=NDxwq4o&sid=021dfdd91a4e4b22bb4dcfd726465c93 HTTP/1.1" 200 183 0.001144
(22408) accepted ('127.0.0.1', 52035)
(22408) accepted ('127.0.0.1', 52036)
--------------------------------------------
socket is, <flask_socketio.SocketIO object at 0x04CC6F90>
127.0.0.1 - - [23/Jul/2020 19:14:47] "GET /aptitude/startAptitude HTTP/1.1" 200 2095 0.022539
127.0.0.1 - - [23/Jul/2020 19:14:47] "GET /socket.io/?EIO=3&transport=websocket&sid=021dfdd91a4e4b22bb4dcfd726465c93 HTTP/1.1" 200 0 5.763522
任何帮助都将有很多意义。谢谢
答案 0 :(得分:1)
连接到Socket.IO服务器时,通常不使用URL,而只是连接到服务器,让系统使用默认端点:
var socket = io.connect("http://127.0.0.1:5000");
这使很多人感到困惑,但是当您添加路径时,Socket.IO将其视为namespace,而不是路由。
因此,正在发生的事情是您的客户端正在自定义名称空间上进行连接,但是服务器正在侦听默认名称空间,因此事件永远不会触发。