javascript - 在域上运行 socket.io
问题描述
我如何在域上运行 socket.io,因为我的代码在 localhost:3000 上运行,但在域上不运行?这是否必须以某种方式公开,以便可以在任何地方使用?
请帮我解决一下这个。谢谢!
Script.js(客户端)
const socket = io("http://localhost:3000");
const messageContainer = document.getElementById('message-container')
const messageForm = document.getElementById('send-container')
const messageInput = document.getElementById('message-input')
const name = prompt('What is your name?')
appendMessage('You joined')
socket.emit('new-user', name)
socket.on('chat-message', data => {
appendMessage(`${data.name}: ${data.message}`)
})
socket.on('user-connected', name => {
appendMessage(`${name} connected`)
})
socket.on('user-disconnected', name => {
appendMessage(`${name} disconnected`)
})
messageForm.addEventListener('submit', e => {
e.preventDefault()
const message = messageInput.value
appendMessage(`You: ${message}`)
socket.emit('send-chat-message', message)
messageInput.value = ''
})
function appendMessage(message) {
const messageElement = document.createElement('div')
messageElement.innerText = message
messageContainer.append(messageElement)
}
Server.js(服务器端)
const io = require('socket.io')(3000, {
cors: {
origin: "*",
},
});
console.log("Port 3000")
const users = {}
io.on('connection', socket => {
socket.on('new-user', name => {
users[socket.id] = name
socket.broadcast.emit('user-connected', name)
})
socket.on('send-chat-message', message => {
socket.broadcast.emit('chat-message', { message: message, name: users[socket.id] })
})
socket.on('disconnect', () => {
socket.broadcast.emit('user-disconnected', users[socket.id])
delete users[socket.id]
})
})
解决方案
将端口更改为 80(如果您使用 http)或 443(如果您使用 https)
const io = require('socket.io')(80, {
cors: {
origin: "*",
},
});
--
const socket = io("http://website.com:80");
推荐阅读
- java - 如何调用两个并行返回 DeferredResult<> 的方法?
- neo4j - Neo4j中链表的字段数组
- mysql - MySQL 删除子查询成本数百秒,而选择查询成本低得多
- html - 如何防止 TinyMCE 清理“&”
- python - Django:使用默认过滤器扩展 QuerySet
- python-3.x - ModuleNotFoundError:尽管模型似乎已安装,但没有名为“matplotlib”的模块
- google-cloud-platform - Airflow 的 DataprocPySparkOperator 一小时后超时(使用 Google Cloud Composer)
- excel - 使用 MID 和 FIND 将字符串中的数据提取到 Excel 单元格中
- ssis - 在 Foreach 循环中将数据插入到 Dynamics crm
- php - 如何通过 Script\Event 获取作曲家自动加载类映射?