也许我没有完全理解相关问题的答案。我得到了长轮询、反向 ajax 概念,但事情是这样的:
我当前的设置是在我的本地单位,我是客户端,我是服务器。我可以成功建立与服务器的连接,一旦建立连接,我就可以向客户端发送一条消息,现在出现另一种情况,我只想服务器在建立连接后不断更新我的客户端。为了简单起见,假设我希望我的客户端随服务器时间进行更新,以便每次分钟发生变化时,服务器都会向客户端发送最新时间(前提是连接已建立)。
我正在使用node.js和socket.io。以下是我的代码:
客户:
<!DOCTYPE html>
<meta charset="utf-8" />
<title>WebSocket Testing</title>
<script src="/socket.io/socket.io.js"></script>
<script language="javascript" type="text/javascript">
var socket = new io.connect("http://127.0.0.1:8080");
socket.on('connect', function(){
// socket.on('news', function (data) {
// socket.emit('my other event', { my: 'data' });
socket.on("test",function(data){
alert(data);
});
socket.onmessage = function (event) {
console.log(event.data);
}
});
console.log(socket);
</script>
<h2>WebSocket Test</h2>
<div id="output"></div>
</html>
服务器:
var socketOptions = {
transportOptions: {
'xhr-polling': {
closeTimeout: 20000000, //20 mins
timeout: 20000000 //20 mins
}
}
};
var app = require('http').createServer(handler)
, url = require('url')
, io = require('socket.io').listen(app,socketOptions)
, fs = require('fs')
app.listen(8080);
function handler (req, res) {
var path = url.parse(req.url).pathname;
fs.readFile(__dirname + '/index.html',
function (err, data) {
if (err) {
console.log("ERROR: "+err)
res.writeHead(500);
return res.end('Error loading index.html');
}
// res.writeHead(200);
//res.writeHead(200, {'Content-Type': path == 'json.js' ? 'text/javascript' : 'text/html'})
res.writeHead(200, {'Content-Type': 'text/html'});
console.log("THIS IS IT");
res.end(data);
});
}
console.log(io);
io.sockets.on('connection', function (socket) {
// socket.send("testing lang kung nagsesend");
// console.log("connection");
// socket.emit('news', { hello: 'world' });
// socket.on('my other event', function (data) {
// console.log(data);
// });
socket.emit("test","Test connection message established,send and received");
});
我该如何处理我的服务器代码?我注意到几乎所有代码示例都是 php 格式。
最佳答案
使用回调中的函数创建一个 setInterval,您希望它在连接
被触发后设置秒数执行该操作。您正在寻找这样的东西:
io.sockets.on('connection', function (socket) {
setInterval(function(){
// do a socket emit here to give data to client
},1000);
}
关于php - 服务器到客户端的更新,无需来自客户端 Websocket 编程的持续/持久请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14997512/