javascript - Meteor 中使用 bcrypt.compare 驗(yàn)證密碼,如何在回調(diào)函數(shù)中修改全局變量?
問(wèn)題描述
如題,自己造輪子的過(guò)程中,在服務(wù)器端利用 bcrypt.compare 做密碼驗(yàn)證,想在回調(diào)函數(shù)中來(lái)修改全局變量 info,如何實(shí)現(xiàn)?自己寫(xiě)的代碼如下:
Meteor.methods({ userLogin: (username, password) => {let user = Users.find({username: username}).fetch()[0];let info;bcrypt.compare(password, user.password, (err, res) => { if (err) { info = { status: 0, data: err} } // res == true 輸入的密碼與保存的密碼一致 if (res) {info = { status: 1, data: [{_id: user._id,username: user.username,group: user.group }]}; } else {info = { status: 0, data: 'username or password invalid'}; }});console.log(info);return info; }});
console.log(info);打印的內(nèi)容為 undefined
嘗試過(guò)將 info 改成 window.info (ps:網(wǎng)上找到解決方案,我也不知道為什么要這樣做), 但直接報(bào)錯(cuò),之前在寫(xiě) react 組件時(shí)也遇到類(lèi)似的情況,通過(guò)給 callback 綁定 this 解決的,但在這里給(err, res) => {}.bind(this)后,依舊是 undefined
問(wèn)題解答
回答1:bcrypt.compare 是一個(gè)異步方法,你console.log的時(shí)候,info還沒(méi)有被賦值,這種情況下你應(yīng)該把你的方法也改成異步方法,讓userLogin返回Promise,然后在bcrypt完成以后resolve(info)
