gpt4 book ai didi

javascript 将我的身份验证功能变成一个 promise

转载 作者:行者123 更新时间:2023-11-28 20:28:49 28 4
gpt4 key购买 nike

这是我的访问函数的示例,我用它来检查用户是否经过身份验证。

access = function(id, user_id, callback) {
docs.findOne({
_id: id
}, function(err, doc) {
if (doc.user.indexOf(user_id) != -1) {
callback("authenticated")
} else {
callback();
}
});
}

我将它与这样的回调模式一起使用。

access(id, user, function (status) {
if (status == 'authenticated') doSomething()
})

我发现写起来有点无聊,因为每次使用访问函数时您确实需要检查回调状态。我想要一种更好的方法来使用访问函数,以便在回调上进行身份验证。像这样的吗?

access(id, user, function () {
doSomething()
}).err(function () {
doSomethingElse()
})

最佳答案

如果您想要半小时以视频形式介绍 Promise,我建议您观看 JSConf.eu 的演讲:http://youtu.be/qbKWsbJ76-s

从你的问题中我得到的印象是,你以前没有真正研究过 Promise(并且从其他一些答案来看,并非所有人都知道)。

JavaScript promise 在 Promises/A+ 中定义规范。它很容易阅读,所以值得一看。并非所有 promise 都遵循此规范(jQuery 是唯一真正值得注意的异常(exception)),但您可以找到兼容实现的列表 here

作为新人:

如果你想了解 Promise 是如何实现的,promise是最简单的之一(它也具有最快的性能之一)。 免责声明:我写了这个

但是 Promise 非常有限,因此如果没有大量扩展,它就没有多大用处。我建议您使用Q首先,因为它是最受欢迎的之一,并且具有许多功能,使其使用起来更加简单。 Q 也最适合 future 规范中的大多数想法。

如果您使用 Mongoose 作为数据库驱动程序,它带有自己的 Promises/A+ 实现,因此您可以使用它:

access = function(id, user_id) {
return docs.findOne({
_id: id
})
.then(function(doc) {
if (doc.user.indexOf(user_id) == -1) {
throw new Error('User Not Found')
}
});
}

这里发生的事情是 docs.findOne 返回一个“promise”,因为它是在没有回调的情况下调用的。 .then 附加的处理程序添加了一个回调。它还返回一个新的 Promise,并且第一个 Promise 中的任何错误都会自动传播到新的 Promise。如果回调中抛出错误,则新的 Promise 将被“拒绝”。如果回调返回一个值,则新的 Promise 将用该值“履行”。

定义我们的函数后,我们可以调用它:

access(id, user_id)
.then(function () {
doSomething();
});

如果在某个时候我们想要处理该错误,我们可以通过附加错误处理程序来实现:

access(id, user)
.then(function () {
doSomething()
}, function (err) {
doSomethingElse()
})

唯一的问题是,如果 doSomething 抛出错误,它将被静音(这很糟糕)。如果您完成了对 promise 的链接 .then 调用,您需要结束该链。

如果您使用 Mongoose 内置的 promise ,那么您可以调用 end

access(id, user)
.then(function () {
doSomething()
}, function (err) {
doSomethingElse()
})
.end();

如果您使用 Q Promise 那么您会调用 done

access(id, user)
.then(function () {
doSomething()
}, function (err) {
doSomethingElse()
})
.done();

如果您有一个 Mongoose promise 想要转换为 Q promise ,您只需将其传递给 Q:

Q(access(id, user))
.then(function () {
doSomething()
}, function (err) {
doSomethingElse()
})
.done();

如果您不使用 Mongoose

如果您不使用 Mongoose 并且需要从头开始创建 Q promise ,则可以使用 Q.promise

var promise = Q.promise(function (resolve, reject) {
docs.findOne({
_id: id
}, function(err, doc) {
if (doc.user.indexOf(user_id) != -1) {
resolve("authenticated")
} else {
reject(new Error("User Not Found"));
}
});
})

还有一个处理 Node 样式 API 的快捷方式:

var findOne = Q.denodeify(docs.findOne);
var promise = findOne({_id: id});

设计推理

最后,如果您想知道为什么 Promise 会这样工作,或者您认为他们的设计在某种程度上很愚蠢,https://github.com/kriskowal/q/blob/master/design/README.js是一位出色的导游。它引导您从头开始开发 Promise 库,几乎完全从您认为“回调不够好”开始,一直到完整的 Promise 库。

关于javascript 将我的身份验证功能变成一个 promise ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16822074/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com