我正在学习 Node
、Express
和 Socket.io
聊天教程。我决定使用 Redis
来存储聊天记录并已成功设置,以便我的信息正确发布到数据库中。我现在正在尝试访问该信息以在客户端使用(在这种情况下,我正在尝试访问当前聊天中的用户列表,以便我可以将他们显示在聊天的一侧)。我正在使用 $.getJSON
发出 GET
请求。现在我已经设置好它试图访问的文件只有这个 JSON
对象:{"dog": "2","cat":"3"}
只是为了测试它,这是有效的,但我不确定从那里去哪里,因为每当我尝试向该文件添加一个函数时,即使我指定返回一个 JSON 对象并调用该函数,请求也会停止返回正确的信息。
例如我试过:
var data = function(){
return {"dog" : "2","cat":"3"}
}
data();
并且不返回任何内容(我知道当我发出 GET
请求时,该函数没有运行,但它甚至不返回该文本,如果它不返回运行一个函数,我不确定如何从这个文件访问 redis)
这是我的想法:
var redis = require('redis')
//figure out how to access the redis client that I have at localhost:6379, something like var db = redis.X
//and then call (for example) db.smembers('onlineUsers') and be returned the object which I can iterate through
这是我的相关代码:
server.js:
var jade = require('jade');
var PORT = 8080;
var redis = require('redis');
var db = redis.createClient();
var pub = redis.createClient();
var sub = redis.createClient();
var http = require('http');
var express = require('express');
var app = express();
var server = http.createServer(app);
var io = require('socket.io').listen(server);
server.listen(PORT, function(){
console.log("Now connected on localhost:" + PORT)
});
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.set("view options", {layout: false});
app.use(express.static(__dirname + '/public'));
app.get('/', function(req, res){
res.render('home');
});
io.sockets.on('connection', function(client){
sub.subscribe("chatting");
sub.on("message", function (channel, message) {
console.log("message received on server from publish");
client.send(message);
});
client.on("sendMessage", function(msg) {
pub.publish("chatting",msg);
});
client.on("setUsername", function(user){
pub.publish("chatting","A new user in connected:" + user);
db.sadd("onlineUsers",user);
}
);
client.on('disconnect', function () {
sub.quit();
pub.publish("chatting","User is disconnected :" + client.id);
});
});
script.js:
$(document).ready( function(){
$client = io.connect();
initialize();
});
var setUsername = function(){
var username = $("#usernameInput").val();
if (username)
{
var user = username;
$client.emit('setUsername', username);
$('#chatControls').show();
$('#usernameInput').hide();
$('#usernameSet').hide();
showCurrentUsers();
}
}
var showCurrentUsers = function(){
$('#list_of_users').empty();
$.getJSON('getusers.js', function(data){
for (var i = 0; i < data.length; i++){
$('list_of_users').append("<li>"+data[i]+"</li>")
}
})
}
var sendMessage = function(){
var msg = $('#messageInput').val();
var username = $("#usernameInput").val();
if (msg)
{
var data = {msg: msg, user: username}
$client.emit('message', data);
addMessage(data);
$('#messageInput').val('');
// populate(username,msg);
}
}
var addMessage = function(data) {
$("#chatEntries").append('<div class="message"><p>' + data.user + ' : ' + data.msg + '</p></div>');
}
// var populate = function(username,msg) {
// var data ;
// }
var initialize = function(){
$("#chatControls").hide();
$("#usernameSet").on('click', setUsername);
$("#submit").on('click',sendMessage);
showCurrentUsers();
}
现在 getusers.js
文件中的所有内容是:
{"dog": "2","cat":"3"}
最佳答案
看起来您希望调用 $.getJSON 来加载并执行它加载的 javascript。这种方式行不通。您需要创建一个呈现 JSON 的 Node 端点(通过路由)。然后 Node 端点将进行数据操作/查询 redis:
Node :
在 routes.js 中:
app.get('/chatdata', ChatController.getChatData);
在 ChatController.js 中(操作,在这里创建你喜欢的数据)
exports.getChatData = function (req, res) {
var data = function(){
return {"dog" : "2","cat":"3"}
};
res.JSON(data);
};
前端
$.getJSON('getChatData', function(data){
//...
})
关于javascript - 使用 Node.js 通过 AJAX 请求从 Redis 检索数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24454310/