Как я могу подключить клиент Javascript к серверу Python -SocketIO? - PullRequest
0 голосов
/ 11 апреля 2020

Я только начинаю Python -SocketIO, я создал пример сервера, он выглядит так:

import eventlet
import socketio

sio = socketio.Server()

app = socketio.WSGIApp(sio, static_files={
    '/': {'content_type': 'text/html', 'filename': 'index.html'}
})

@sio.on('connect')
def connect(sid, environ):
    print('connect ', sid)

@sio.on('msg')
def message(sid, data):
    print('message ', data)

@sio.on('disconnect')
def disconnect(sid):
    print('disconnect ', sid)

if __name__ == '__main__':
    eventlet.wsgi.server(eventlet.listen(('', 5000)), app)

Затем у меня есть HTML файл, который выполняется в приложении Django, я хотел бы подключить этот клиент к моему Python -SocketIO серверу:

<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.2.0/socket.io.js"></script>
<script>

socket = io.connect('');

socket.on('connect',function() {
  console.log('Client has connected to the server!');
});

socket.on('msg',function(data) {
  console.log('Received a message from the server!',data);
});

socket.on('disconnect',function() {
  console.log('The client has disconnected!');
});

// Sends a message to the server via sockets
function send(message) {
  socket.send('msg',message);
};

</script>

Проблема в том, что на стороне клиента я продолжаю получать следующие ошибки:

Access to XMLHttpRequest at 'http://localhost:5000/socket.io/?EIO=3&transport=polling&t=N5eSEa2' from origin 'http://127.0.0.1:8000' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
localhost:5000/socket.io/?EIO=3&transport=polling&t=N5eSEa2:1 Failed to load resource: net::ERR_FAILED

Мой Django сервер работает on http://127.0.0.1:8000/. Может кто-нибудь помочь мне понять, что я делаю не так?

1 Ответ

1 голос
/ 11 апреля 2020

Установите заголовок CORS на вашем сервере:

sio = socketio.Server(cors_allowed_origins='*')

( Источник )

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...