我正在使用一个小型Web框架进行HCI研究,并遇到了以下问题:
我有一个运行express的Node服务器,可以从JSON文件提供本地主机数据。不是最好的数据库,但是由于它是一个单一用户系统(任何时候都只有一个参与者会使用该系统),因此添加任何其他技术确实没有任何意义。以下获取请求代码可以正常工作:
function getUser(id,last) {
return $.ajax({
type: "GET",
url: "/data/user/"+id,
async: false
}).responseJSON;
}
由以下 Node 代码处理:
app.get('/data/:asset/:id', function (req, res) {
var accJSN
res.setHeader('Content-Type', 'application/json');
if(req.params.asset === "user")
{
accJSN = JSON.parse(fs.readFileSync(path.join(__dirname,'/public/data/users.json')));
res.send(JSON.stringify(accJSN.users[req.params.id]));
}
上面的代码产生一个我可以使用/打印的响应,并且包含responseJSON属性。以下代码没有,我会注意到 Node 代码在同一个server.js文件中,带有jquery/ajax调用的函数在我的客户端页面中:
客户端代码:
function getUserset(ids,last) {
userQuery = "";
for(i=0;i<ids.length;i++)
{
userQuery += ids[i] + ",";
}
userQuery = userQuery.slice(0,-1);
return $.ajax({
type: "GET",
url: "/userset?users=["+userQuery+"]",
async: false
}).responseJSON;
}
服务器代码:
app.get('/userset', function (req, res) {
var accJSN = JSON.parse(fs.readFileSync(path.join(__dirname,'/public/data/users.json')));
accJSN = accJSN.users;
var users = JSON.parse(req.query.users);
var resJSN = new Array;
for(var i=0;i<users.length;i++)
{
var temp = {};
temp["id"] = users[i];
temp["fName"] = accJSN[users[i]].fName;
temp["lName"] = accJSN[users[i]].lName;
temp["profilePic"] = accJSN[users[i]].profilePic;
resJSN.push(temp);
}
res.setHeader('Content-Type', 'application/json');
res.send(JSON.stringify(resJSN));
})
我需要的数据实际上可以在响应文本中找到,但是我一生无法弄清楚为什么第二个示例也不包含responseJSON属性,或者,如果我完全错了,为什么第一个示例不包含responseJSON属性。任何想法或解决方案表示赞赏,谢谢!
最佳答案
无需手动设置application/json
header 并发送response
,而只需使用
res.json(resJSN);
代替
res.setHeader('Content-Type', 'application/json');
res.send(JSON.stringify(resJSN));