gpt4 book ai didi

reactjs - 从NextJS上的组件或API路由调用Socket IO实例

转载 作者:行者123 更新时间:2023-12-03 11:59:09 25 4
gpt4 key购买 nike

我正在尝试从API Route端点调用我的套接字服务器实例,以便在我在数据库中保存新记录时向所有Socket IO客户端发送广播。

套接字IO在我的NextJS服务器中正常运行。

我创建了一个自定义./server/index.ts来运行共享同一端口的NextJS服务器和Socket.io服务器。

客户端成功连接到Socket IO服务器。但是现在我希望当从浏览器调用到类似/api/save的API路由时,可以使用我的Socket IO服务器实例进行广播。

但是我不知道如何从项目中的其他文件中获取Socket IO服务器的实例。

谢谢你。

./server/index.ts

import "reflect-metadata";
import { createServer } from 'http'
import { parse } from 'url'
import next from 'next'
import socketIo from "socket.io";

const port = parseInt(process.env.PORT || '3000', 10);
const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();

app.prepare().then(() => {

const http = createServer((req, res) => {
const parsedUrl = parse(req.url!, true);
const { pathname, query } = parsedUrl;

if (pathname === '/a') {
app.render(req, res, '/a', query)
} else if (pathname === '/b') {
app.render(req, res, '/b', query)
} else {
handle(req, res, parsedUrl)
}
}).listen(port);

const ioServer = socketIo(http);
ioServer.on("connection", function (socket) {
console.log('An user has connected!');
socket.on('disconnect', function () {
console.log('An user has disconnected');
});
});

// tslint:disable-next-line:no-console
console.log(
`> Server listening at http://localhost:${port} as ${
dev ? 'development' : process.env.NODE_ENV
}`
);


});

最佳答案

您无需导出实例,只需创建一个函数即可在套接字文件中执行任务,然后导出该函数并在所需的任何地方使用它。

关于reactjs - 从NextJS上的组件或API路由调用Socket IO实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59750678/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com