我使用Nodejs作为应用程序API的后端,但是我意识到,当有2个不同的用户继续请求相同的方法时,有时MySQL请求返回的数据可能会混杂在一起,这是我的代码:
router.get('/v1/getList', function(req, res) {
model.getList(loginUser, function(groups){
if(!groups.length){
res.json({data: '', success: false, message: 'No record found.'});
} else{
console.log("User:"+loginUser+", Length:"+groups.length);
res.json({data: groups, success: true, message: ''});
}
});
});
loginUser
是用户ID。正常情况下,终端输出如下所示,用户1有2个项目,用户2有3个项目:User:1, Length:2
User:2, Length:3
User:1, Length:2
User:2, Length:3
and so on...
但是一旦我不断刷新屏幕,终端可能会返回:
User:1, Length:2
User:2, Length:3
User:1, Length:3
User:2, Length:2
我怀疑用户2正在访问用户2的数据请求,反之亦然,请问该如何解决?
最佳答案
您不能使用全局变量来存储中间件中的loginUser
。一次可能有多个请求在飞行中。这样使用全局变量可以混合来自多个请求的数据。
解决此问题的通常方法是从中间件将数据存储在request
对象本身中。然后,您可以从实际的请求处理程序访问request
对象上的该属性。由于请求对象对于此特定请求是唯一的,因此在来自不同用户的请求之间没有数据的交叉耦合。
您的请求处理程序将变为以下内容(使用req.loginUser
):
router.get('/v1/getList', function(req, res) {
model.getList(req.loginUser, function(groups){
if(!groups.length){
res.json({data: '', success: false, message: 'No record found.'});
} else{
console.log("User:"+loginUser+", Length:"+groups.length);
res.json({data: groups, success: true, message: ''});
}
});
});
并且,您必须修改中间件以设置
req.loginUser
而不是全局变量。