【问题标题】:Why no response socket.io with react.js为什么用 react.js 没有响应 socket.io
【发布时间】:2020-04-01 07:54:00
【问题描述】:

服务器端:

const express = require("express");
const http = require("http");
const socketIo = require("socket.io");
const axios = require("axios");
const port = process.env.PORT || 4001;
const index = require("./routes/index");
const app = express();
app.use(index);
const server = http.createServer(app);
const io = socketIo(server);

let interval;

io.on("connection", socket => {
  console.log("New client connected");
  if (interval) {
    clearInterval(interval);
  }
  interval = setInterval(() => getApiAndEmit(socket), 10000);
  socket.on("disconnect", () => {
    console.log("Client disconnected");
  });
});


const getApiAndEmit = async socket => {
  try {
    const res = await axios.get(
      "https://api.darksky.net/forecast/db057094f57ede5e1f8d33d5e528e4b3/30.9871097,34.9408864"
    );

    let temp = (((res.data.currently.temperature - 32) * 5) / 9).toFixed(2);
    socket.emit("FromAPI", temp);
  } catch (error) {
    console.error(`Error: ${error.code}`);
  }
};

server.listen(port, () => console.log(`Wee wee i'm on port ${port}`));

客户端:

import React, { Component } from "react";
import socketIOClient from "socket.io-client";

class App extends Component {
  constructor() {
    super();
    this.state = {
      response: false,
      endpoint: "http://127.0.0.1:4001"
    };
  }

  componentDidMount() {
    const socket = socketIOClient(this.state.endpoint);
    socket.on("FromAPI", data => this.setState({ response: data }));
  }

  render() {
    const { response } = this.state;
    return (
      <div style={{ textAlign: "center" }}>
        {
        response ? 
        (<p>The temperature is {response} degrees</p>) 
        : 
        (<p>load load...</p>)
        }
      </div>
    );
  }
}

export default App;

2 信息:

[HMR] 等待来自 WDS 的更新信号... 下载 React DevTools 以获得更好的开发体验:fb.me/react-devtools

1 个错误:

http://127.0.0.1:4001/socket.io/?EIO=3&transport=polling&t=N4qdmGu

加载资源失败:net::ERR_CONNECTION_REFUSED

怎么了?

【问题讨论】:

    标签: javascript node.js reactjs express socket.io


    【解决方案1】:

    您应该尝试将客户端的端点设置为“http://localhost:4001”。

    【讨论】:

    • 对不起..一个小错误将“https”替换为“http”。
    • 不帮我 localhost/socket.io/?EIO=3&transport=polling&t=N4sExDT net::ERR_CERT_AUTHORITY_INVALID
    • 您应该确保收到来自该 API 的响应
    • 试试把console.log(res)放到axios下面看看api的响应是什么
    • 控制台上不显示任何内容。但每 10 秒刷新一次。并且错误一次又一次出现
    猜你喜欢
    • 1970-01-01
    • 2014-09-03
    • 1970-01-01
    • 2020-10-16
    • 2021-09-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多