【发布时间】:2021-05-28 14:49:19
【问题描述】:
我想用 Flask 和 socket.io 制作一个聊天应用程序,但每当我点击“发送”时,我总是收到错误 405。我一直在努力完成这项工作,但它不会(只是一个带有用户名和消息的基本东西)。这是错误的内容:
"方法不允许 请求的 URL 不允许该方法。”
我真的不知道出了什么问题。当我检查我的 cmd 时,我看到:
POST / HTTP/1.1" 405 362 0.001000 127.0.0.1 - - [28/May/2021 16:44:29] “GET /socket.io/?EIO=3&transport=websocket&sid=7392cec39d5841bcaa7d7c8faaa1b6fb HTTP/1.1" 200 0 3.134387
main.py:
from flask import Flask, render_template #Importation du modèle flask et de render_template
from flask_socketio import SocketIO #Importation du modèle socketio
app = Flask(__name__)
app.config['SECRET_KEY'] =b'\xba!\xe3];\xce\xe6V}\x1d\xee\xda\x03\x8b\xbfS\xb9\x0fE\x8f\x15\x98O\x92' #Clé secrète afin de garder la partie client sécurisée
socketio = SocketIO(app)
@app.route('/')
def index(): #Définition de la fonction index
return render_template('index.html') #Affichage de la page index.html
def messageReceived(methods=['GET', 'POST']): #Définition de la fonction message reçu
print('Message reçu')
@socketio.on('my event')
def handle_my_custom_event(json, methods=['GET', 'POST']): #Définition de la fonction message envoyé
print('Mon événement a été reçu: ' + str(json))
socketio.emit('Ma réponse', json, callback=messageReceived) #Émission du message
if __name__ == '__main__': #Boucle permettant à l'application web de continuer de fonctionner à l'infinie
socketio.run(app, debug=True)
index.html:
<!DOCTYPE html>
<html lang="fr">
<head>
<meta charset="utf-8">
<title>Chat Flask</title>
<link rel="stylesheet" href="{{url_for('static', filename='index.css')}}">
</head>
<body>
<p id="para1" style='color: #9cd374;font-size: 30px;'>Pas de message...</p>
<div class="message_holder"></div>
<form action="" method="POST">
<div class="inputs">
<input type="text" id="username" placeholder="Nom d'utilisateur"/>
<input type="text" id="message" placeholder="Message"/>
<input type="image" id="send" src="static/send.png"/>
<!-- Utilisation direct du <style> car le css ne fonctionne pas pour les entrées -->
<style>
input[type="email"] {
text-align: center;
}
input[type="text"] {
text-align: right;
}
input[type="tel"] {
text-align: left;
}
body {
text-align: center;
}
label {
display: block;
margin-bottom: 30px;
}
</style>
</div>
</form>
<!-- Script JS nécessaire pour utiliser socketIO -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/socket.io/1.3.6/socket.io.min.js"></script>
<script type="text/javascript">
var socket;
$(document).ready(function(){
socket = io.connect('http://' + document.domain + ':' + location.port + '/chat');
socket.on('connect', function() {
socket.emit('joined', {});
});
socket.on('status', function(data) {
$('#chat').val($('#chat').val() + '<' + data.msg + '>\n');
$('#chat').scrollTop($('#chat')[0].scrollHeight);
});
socket.on('message', function(data) {
$('#chat').val($('#chat').val() + data.msg + '\n');
$('#chat').scrollTop($('#chat')[0].scrollHeight);
});
$('#text').keypress(function(e) {
var code = e.keyCode || e.which;
if (code == 13) {
text = $('#text').val();
$('#text').val('');
socket.emit('text', {msg: text});
}
});
});
</script>
</body>
</html>
【问题讨论】: