[英]koa-router and passport chaining results into callback
好了,所以我最近从快递迁移到了koa,这里的主要问题是有关koa路由器和护照认证的。
回到快递中,我能够做类似的事情
router.route('/someroute')
.post(passport.authenticate('local' , {session:false}) ,
function(req,res,next){req.authresult});
基本发生的事一旦通过护照策略进行了身份验证,在策略中返回的任何对象都将被集中到REQ对象中,我可以在主控制器函数中访问它。 方便吧?
好吧,这就是koa的做法,afaik:
router.post('/someroute' , function(ctx,next){
return passport.authenticate('jwt' ,(err,user,info,status) =>{
....
})(ctx);
现在已经说明了这种情况,我的问题是:
1.是否可以像express那样进行路由
router.post('/someroute',passport.authenticate(..),function(ctx){ ctx.user
});
2.如果我不传递ctx对象,为什么会得到未找到的结果
passport.authenticate(...)(ctx);
将对象放入已定义的方法中,这种实现称为什么。我在哪里可以学到呢?
和往常一样,我已经做了一些研究,并准备自己回答这个问题。
1.是的,可以进行诸如express之类的路由而无需声明护照身份验证的自定义回调。
router.post('../someroute',passport.authenticate('strategy',options),function(ctx){
//access passport return object through ctx.state.user
}
但是,这样做的缺点是,如果该策略返回一个诸如done(err)之类的错误,则错误处理将不会由您的路由回调完成,而是会由koa自动响应内部服务器错误。 如果要返回与auth相关的错误,则必须通过具有添加属性的同一个ctx.state.user对象来完成。
2.passport.authenticate()返回一个函数,该函数期望一个req,res / ctx对象,因此不提供将导致错误(内部诺言拒绝,未提供ctx)。 在上面的声明中,router.post自动处理此问题,但是,在另一个函数中声明它需要您传递ctx。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.