简体   繁体   English

无法使用 socket.io 连接到房间

[英]Not able to connect to rooms with socket.io

I'm using socket io in two places in the app:我在应用程序的两个地方使用套接字 io:

  1. emiting offers on the main page that everyone can see在主页上发布每个人都可以看到的优惠
  2. emiting chat messages only between two users based on order_id根据order_id仅在两个用户之间发出聊天消息

I was able to set up first use case but not the second.我能够设置第一个用例,但不能设置第二个。 When creating a new message, response status is 500 after hitting the socket part in the controller.创建新消息时,在点击 controller 中的套接字部分后,响应状态为 500。

index.js index.js

  const serverIO = server.listen(
    port,
    console.log(`Listening on Port ${port}`)
  );
  const io = require("./socket").init(serverIO);
  io.on("connection", (socket) => {
    socket.join("some room");
    console.log("cient connected");
  });

socket.js socket.js

let io;

module.exports = {
  init: (httpServer) => {
    io = require("socket.io")(httpServer);
    return io;
  },
  getIO: (socket) => {
    if (!io) {
      throw new Error("Socket.io not initialized!");
    }
    console.log("socket", socket());
    return io;
  },
};

chatController.js聊天控制器.js

const io = require("../socket");
const chatModel = require("./chatModel.js");

exports.createChat = async (req, res) => {
  try {
    const savedMessage = await chatModel.saveMessage(req.body);
    if (!savedMessage) {
      return res.status(400).json({
        errorMessage: "Something went wrong with your chat request",
      });
    }
    io.getIO().socket.to(req.body.order_id).emit("newMessage", { action: "create", message: savedMessage });
    return res.status(200).json(savedMessage);
  } catch (error) {
    return res.status(500).json({
      errorMessage: error,
    });
  }
};

on the client, I'm listening like this:在客户端上,我正在这样听:

Chat.js聊天.js

useEffect(() => {
    const socket = openSocket(baseURL);
    socket.on("newMessage", ({ room, data }) => {
      console.log("room", room); //not being reached
      if (data.action === "create") {
        dispatch(addMessage(...data.message));
      }
    });
  }, []);

I tried adding the boilerplate code from documentation but that didn't seem to work.我尝试从文档中添加样板代码,但这似乎不起作用。

io.on('connection', socket => {
  socket.join('some room');
});

How can I join rooms based on orderId and listen to said room on the client?如何根据 orderId 加入房间并在客户端收听所述房间?

Was able to reach a working solution (chat messages are being broadcast only to the intended recipients)but don't know if it's optimal or efficient.能够找到一个可行的解决方案(聊天消息只广播给预期的接收者),但不知道它是否是最佳的或有效的。

added socket.join in my index.js file在我的 index.js 文件中添加了 socket.join

io.on("connection", (socket) => {
   socket.on("joinRoom", (room) => {
      console.log("joined room");
      socket.join(room);
    });

    console.log("cient connected");
  });

modified my controller修改了我的 controller

io.getIO().to(req.body.order_id).emit("newMessage", {
      action: "create",
      message: savedMessage,
    });

And on the front end, on mount, I'm joining a room and listening for newMessage from server.在前端,在安装时,我正在加入一个房间并收听来自服务器的 newMessage。

  useEffect(() => {
    const socket = openSocket(baseURL);
    socket.emit("joinRoom", orderId);
    socket.on("newMessage", (data) => {
      console.log("data", data);
      if (data.action === "create") {
        dispatch(addMessage(...data.message));
      }
    });
  }, []);

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM