首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何允许来自react的python flask socketio中的cors policy policy

如何允许来自react的python flask socketio中的cors policy policy
EN

Stack Overflow用户
提问于 2021-04-12 14:49:13
回答 1查看 292关注 0票数 0

这是我的server.py文件。我已经使用了socketio来从react应用程序调用。

代码语言:javascript
复制
async_mode = None
app = Flask(__name__)
app.debug = True
app.config['SECRET_KEY'] = 'nuttertools'
Session(app)
CORS(app)
cors = CORS(app, resources={r"*": {"origins": "*"}})

# socketio = SocketIO(app, manage_session=False, async_mode=async_mode)
socketio = SocketIO(app, manage_session=False, async_mode=async_mode, cors_allowed_origins='*')

@socketio.on('message', namespace='/chat')
def chat_message(message):
    print("message =!! ", message)
    test_message = message
    print("test message ", test_message)

    emit('message', {'data': test_message['data']}, broadcast=False)

if __name__ == '__main__':
    socketio.run(app, host=host, port=port, debug=True)

但是当我从react应用程序调用这个socketio时,我得到了以下错误。

代码语言:javascript
复制
Access to XMLHttpRequest at 'http://localhost:5003/socket.io/?EIO=3&transport=polling&t=NZ4y_ZW' from origin
 'http://localhost:3000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

我的react代码如下:

代码语言:javascript
复制
const serverHost = window.location.hostname;
const serverPort = 5003;
const serverUrl = `http://${serverHost}:${serverPort}/chat`;
console.log(serverUrl);

class App extends Component {
    constructor(props) {
        super(props);
        // this.completeChange = this.completeChange.bind(this);
        this.state = {
            userMessage: '',
            conversation: [{
                text: "Please enter your mobile number",
                user: 'ai',
            }],
            socket: io(serverUrl),
            childVisible: false,
            show: false,
            selectedValue: undefined,
            radioOptions: [],
            headerControler: false,
            mobileNoTaken: false
        };
    }

如何解决corse源策略错误?

EN

回答 1

Stack Overflow用户

发布于 2021-04-12 14:54:34

Cors错误可以像这样处理

代码语言:javascript
复制
const io = require("socket.io")(httpServer, {
  origins: ["https://example.com"],

  // optional, useful for custom headers
  handlePreflightRequest: (req, res) => {
    res.writeHead(200, {
      "Access-Control-Allow-Origin": "https://example.com",
      "Access-Control-Allow-Methods": "GET,POST",
      "Access-Control-Allow-Headers": "my-custom-header",
      "Access-Control-Allow-Credentials": true
    });
    res.end();
  }
});

参考:Socket-cors-handling

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67053762

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档