Bil*_*lie 5 python cross-domain flask flask-socketio
我写了这个简单的flask-socketio代码:
from flask import Flask
from flask_socketio import SocketIO, send
app = Flask(__name__)
app.config['SECRET_KEY'] = 'mysecret'
socketio = SocketIO(app)
@socketio.on('message')
def handle_message(msg):
print 'Message:' + msg
send(msg, broadcast=True)
if __name__ == '__main__':
socketio.run(app)
Run Code Online (Sandbox Code Playgroud)
当我看到 chrome 网络分析时,我可以看到“Access-Control-Allow-Origin”值为null.
根据Flask-socketio文档:(见API Reference@ http://flask-socketio.readthedocs.io/en/latest/)
Parameters:
...
cors_allowed_origins – List of origins that are allowed to connect to this server. All origins are allowed by default.
Run Code Online (Sandbox Code Playgroud)
我在搜索中发现的另一个建议是使用flask-CORS:
app.config['SECRET_KEY'] = 'mysecret'
cors = CORS(app)
socketio = SocketIO(app)
Run Code Online (Sandbox Code Playgroud)
我得到相同的结果。
使用flask-socketio 允许跨域请求的方法是什么?
提前致谢。
Ron*_*nio 20
下面为我解决。来自 Angular 应用的交互。
socketio = SocketIO(app, cors_allowed_origins="*")
Run Code Online (Sandbox Code Playgroud)
Flask-SocketIO 上默认启用跨源。我的猜测是你测试的方式是有缺陷的。Access-Control-Allow-Origin在运行示例应用程序时,我可以向主 Socket.IO 端点发送请求,并且在响应中获取标头:
~ $ http http://localhost:5000/socket.io/
HTTP/1.1 200 OK
Access-Control-Allow-Credentials: true
Access-Control-Allow-Origin: *
Connection: keep-alive
Content-Length: 119
Content-Type: application/octet-stream
Date: Fri, 01 Jun 2018 17:10:01 GMT
Set-Cookie: io=dd8d67788df54510830fea64bc82b1fd
+-----------------------------------------+
| NOTE: binary data not shown in terminal |
+-----------------------------------------+
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5011 次 |
| 最近记录: |