GET http://localhost:4000/socket.io/?EIO=3&transport=polling&t=MksWDkB 404 (не найдено) - PullRequest
0 голосов
/ 03 июля 2019

Я пытаюсь создать приложение веб-сокета клиент-сервер, но не могу соединить клиентскую и серверную стороны.

Я пробовал другие подобные проблемы, такие как здесь , ни один из них не работал.

Я настроил свой экспресс с помощью генератора экспрессов.

//app.js Server side 
//it's running on port 4000
const createError = require('http-errors');
const express = require('express');
const path = require('path');
const cookieParser = require('cookie-parser');
const logger = require('morgan');

const http = require('http');
const socketIO = require('socket.io');

const indexRouter = require('./routes/index');

const app = express();
const server = http.createServer(app);
const io = socketIO(server);

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'pug');

app.use(logger('dev'));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

// app.use(cors());
app.use((req, res, next) => {
  res.setHeader('Access-Control-Allow-Origin', '*');
  res.setHeader(
    'Access-Control-Allow-Methods',
    'OPTIONS, GET, POST, PUT, PATCH, DELETE'
  );
  res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');
  next();
});

app.use('/', indexRouter);
io.on('connection', socket => {
  console.log('user connected');

});
// catch 404 and forward to error handler
app.use((req, res, next) => {
  next(createError(404));
});

// error handler
app.use((err, req, res, next) => {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render('error');
});

module.exports = app;

вот мой код на стороне клиента

//client side
import React, { Component } from 'react';
import socketIOClient from 'socket.io-client';

const socket = socketIOClient.connect('http://localhost:4000');

class Posts extends Component {

  componentDidMount = () => {
    console.log(socket);
    socket.on('connect', () => console.log('Socket is connected'));
  };

  render() {
    return (
      <div }>
      //codes
      </div>
    );
  }
}
export default Posts;

вывод для сокета внутри componentDidMount -

_callbacks: Object { "$connecting": (1) […], "$connect": (2) […] }

acks: Object {  }
​
connected: false
​
disconnected: true
​
flags: Object {  }
​
ids: 0
​
io: Object { _reconnection: true, _reconnectionDelay: 1000, _reconnectionDelayMax: 5000, … }
​
json: Object { nsp: "/", ids: 0, connected: false, … }
​
nsp: "/"
​
receiveBuffer: Array []
​
sendBuffer: Array []
​
subs: Array(3) [ {…}, {…}, {…} ]
​
<prototype>: Object { addEventListener: addEventListener(), on: addEventListener(), once: once(), … }

Я ожидаю получить консоль на стороне сервера: «пользователь подключен», но я получаю 404. Не найдено.

Я использую

"socket.io": "^2.2.0",
"react": "^16.8.6",
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...