我一直试图通过socket io从flask发送数据。我需要从不同的来源访问这些数据,但它给出了一个CORS错误。我尝试过使用各种交叉起源的东西,但没有一个起作用。有人可以帮忙吗。
应该调用的视图认为socket io:
from flask.ext.cors import cross_origin
@socketio.on('increment',namespace="/api")
@cross_origin()
def increment(message):
number += 1;
emit('number',{'data':number},broadcast=True)
运行服务器:
app = Flask(__name__)
cors = CORS(app,resources={r"/api/*":{"origins":"*"}})
socketio = SocketIO(app)
app.debug = True
app.host = '0.0.0.0'
socketio.run(app)
答案 0 :(得分:5)
我通过以下方法解决了
socketio = SocketIO(app, cors_allowed_origins="*")
答案 1 :(得分:1)
检查您的 html 文件中是否使用了受支持的 socket.io 版本。
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/3.0.4/socket.io.js" integrity="sha512-aMGMvNYu8Ue4G+fHa359jcPb1u+ytAF+P2SCb+PxrjCdO3n3ZTxJ30zuH39rimUggmTwmh2u7wvQsDTHESnmfQ==" crossorigin="anonymous"></script>
答案 2 :(得分:0)
我有类似的问题,让它使用此设置:
#you may not need all these options
from flask import Flask, render_template, request
from flask.ext.socketio import SocketIO, emit, join_room, leave_room
from flask.ext.cors import CORS
app = Flask(__name__, template_folder='./', static_folder='./', static_url_path='')
app.config['SECRET_KEY'] = 'some-super-secret-key'
app.config['DEFAULT_PARSERS'] = [
'flask.ext.api.parsers.JSONParser',
'flask.ext.api.parsers.URLEncodedParser',
'flask.ext.api.parsers.FormParser',
'flask.ext.api.parsers.MultiPartParser'
]
cors = CORS(app,resources={r"/*":{"origins":"*"}})
socketio = SocketIO(app)
socketio.run(app,port=5000,host='0.0.0.0')
您可以这样设置路线:
@app.route("/")
def indexRoute():
return render_template('index.html',version=VER)
和套接字请求:
@socketio.on('connect',namespace="/home")
def test_connect():
print "client connected:",rooms()[0]
在JS的客户端,我做了以下事情:
var socket = io.connect('http://' + location.hostname + ':5000/home');
socket.on('connect',function(data) {
console.log('connected to socket');
});
另外,请查看Flask开发人员的this代码段。