使用sails.js实现护照-http-bearer令牌

穆罕默德·赖汉·穆海敏

我正在尝试实施通行证的passport-http-bearer策略,但是没有找到info的用户Bearer realm="Users"

request是一个发帖请求:

{'token':'simple_access_token',} 

有人知道为什么会发生此错误吗?我也知道这里req应该是httpsssl代替http我怎么做?

我使用的代码是:

bearerPassportToken: function(req,res){
        passport.authenticate('bearer', function(err, user, info){
          if ((err) || (!user)) {
            if (err) return;
            if (!user)  
                console.log("info");//Info: Bearer realm="Users"
            res.redirect('/login');
            return;
          }
          req.logIn(user, function(err){
            if (err){
                res.redirect('/login');
            }
            //Need to write code for redirection
            ;
          });
        })(req, res);
    },
布雷迪欣

我们最近不得不用承载令牌实现基于Sails的API的安全,这就是我们所做的(已通过测试0.9.x):

1)将护照作为自定义中间件连接到config/passport.js(或者可以config/express.js,取决于您的口味):

/**
 * Passport configuration
 */
var passport = require('passport');

module.exports.express = {
  customMiddleware: function(app)
  {
    app.use(passport.initialize());
    app.use(passport.session());
  }
};

2)通过以下策略保护必要的控制器/动作config/policies.js

module.exports.policies = {
  // Default policy for all controllers and actions
  '*': 'authenticated'
};

3)创建检查承载的策略api/policies/authenticated.js

/**
 * Allow any authenticated user.
 */
var passport = require('passport');

module.exports = function (req, res, done) {
  passport.authenticate('bearer', {session: false}, function(err, user, info) {
    if (err) return done(err);
    if (user) return done();

    return res.send(403, {message: "You are not permitted to perform this action."});
  })(req, res);
};

4)在以下位置定义护照的承载策略services/passport.js(或在其他地方找到更适合您的特定应用程序的策略):

var passport = require('passport'),
  BearerStrategy = require('passport-http-bearer').Strategy;

/**
 * BearerStrategy
 *
 * This strategy is used to authenticate either users or clients based on an access token
 * (aka a bearer token).  If a user, they must have previously authorized a client
 * application, which is issued an access token to make requests on behalf of
 * the authorizing user.
 */
passport.use('bearer', new BearerStrategy(
  function(accessToken, done) {
    Tokens.findOne({token: accessToken}, function(err, token) {
      if (err) return done(err);
      if (!token) return done(null, false);
      if (token.userId != null) {
        Users.find(token.userId, function(err, user) {
          if (err) return done(err);
          if (!user) return done(null, false);
          // to keep this example simple, restricted scopes are not implemented,
          // and this is just for illustrative purposes
          var info = { scope: '*' }
          done(null, user, info);
        });
      }
      else {
        //The request came from a client only since userId is null
        //therefore the client is passed back instead of a user
        Clients.find({clientId: token.clientId}, function(err, client) {
          if (err) return done(err);
          if (!client) return done(null, false);
          // to keep this example simple, restricted scopes are not implemented,
          // and this is just for illustrative purposes
          var info = { scope: '*' }
          done(null, client, info);
        });
      }
    });
  }
));

这样,您就可以通过在Authorization标题中包含您的载体来访问API Bearer 8j4s36...

在此示例中,使用了一个单独的服务器来请求/发出令牌,但您也可以在同一应用程序中执行此操作(然后,您必须将策略仅应用于选定的控制器)。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

持护照和sails.js实现的持久会话

来自分类Dev

使用Identity Core发行Bearer JWT令牌

来自分类Dev

在Azure AD中使用Bearer令牌刷新

来自分类Dev

Sails 插座授权(使用护照)

来自分类Dev

Sails.js HOWTO:实现HTTP请求的日志记录

来自分类Dev

Sails.js:如何在使用Sails-generate-auth注册用户后返回访问令牌?

来自分类Dev

使用'Bearer'身份验证令牌来响应本机映像

来自分类Dev

如何使用Bearer令牌从Azure DevOps调用REST API

来自分类Dev

Sails.js + Nginx代理背后的护照

来自分类Dev

带护照的Sails.js中的JWT

来自分类Dev

带护照的Sails.js中的JWT

来自分类Dev

使用Microsoft Graph令牌和Jwt Bearer令牌保护ASP.NET Core Web API

来自分类Dev

使用tcpdump捕获http令牌

来自分类Dev

如何解决护照-http-bearer TypeScript重载类型问题?

来自分类Dev

使用sails.js修改响应标头以实现HSTS

来自分类Dev

Sails.js 0.11和护照:“缺少凭据”错误

来自分类Dev

Sails.js 0.11和护照:“缺少凭据”错误

来自分类Dev

通过Sails-Generate-Auth使用护照蒸汽

来自分类Dev

MVC POST请求丢失了Authorization标头-检索后如何使用API Bearer令牌

来自分类Dev

在ASP.NET Core 2.2中使用nswag设置Bearer令牌

来自分类Dev

如何使用Bearer令牌在我的网站中授权Web api控制器?

来自分类Dev

如何在NodeJ中使用.pfx证书和密码验证Bearer令牌?

来自分类Dev

Azure:使用Bearer令牌访问https://login.microsoftonline.com/{tenant-id}/saml2

来自分类Dev

使用来自Azure AD的Bearer令牌来保护ASP.Net Core 3.1 API

来自分类Dev

如何禁用访问 - 使用 Bearer 令牌请求标准 MVC 控制器

来自分类Dev

无法使用 Azure Active Diectory Bearer 令牌对 Azure Functions 进行身份验证

来自分类Dev

使用 Xml HTTP 请求获取访问令牌

来自分类Dev

护照-Node.js不返回刷新令牌

来自分类Dev

护照-Node.js不返回刷新令牌

Related 相关文章

  1. 1

    持护照和sails.js实现的持久会话

  2. 2

    使用Identity Core发行Bearer JWT令牌

  3. 3

    在Azure AD中使用Bearer令牌刷新

  4. 4

    Sails 插座授权(使用护照)

  5. 5

    Sails.js HOWTO:实现HTTP请求的日志记录

  6. 6

    Sails.js:如何在使用Sails-generate-auth注册用户后返回访问令牌?

  7. 7

    使用'Bearer'身份验证令牌来响应本机映像

  8. 8

    如何使用Bearer令牌从Azure DevOps调用REST API

  9. 9

    Sails.js + Nginx代理背后的护照

  10. 10

    带护照的Sails.js中的JWT

  11. 11

    带护照的Sails.js中的JWT

  12. 12

    使用Microsoft Graph令牌和Jwt Bearer令牌保护ASP.NET Core Web API

  13. 13

    使用tcpdump捕获http令牌

  14. 14

    如何解决护照-http-bearer TypeScript重载类型问题?

  15. 15

    使用sails.js修改响应标头以实现HSTS

  16. 16

    Sails.js 0.11和护照:“缺少凭据”错误

  17. 17

    Sails.js 0.11和护照:“缺少凭据”错误

  18. 18

    通过Sails-Generate-Auth使用护照蒸汽

  19. 19

    MVC POST请求丢失了Authorization标头-检索后如何使用API Bearer令牌

  20. 20

    在ASP.NET Core 2.2中使用nswag设置Bearer令牌

  21. 21

    如何使用Bearer令牌在我的网站中授权Web api控制器?

  22. 22

    如何在NodeJ中使用.pfx证书和密码验证Bearer令牌?

  23. 23

    Azure:使用Bearer令牌访问https://login.microsoftonline.com/{tenant-id}/saml2

  24. 24

    使用来自Azure AD的Bearer令牌来保护ASP.Net Core 3.1 API

  25. 25

    如何禁用访问 - 使用 Bearer 令牌请求标准 MVC 控制器

  26. 26

    无法使用 Azure Active Diectory Bearer 令牌对 Azure Functions 进行身份验证

  27. 27

    使用 Xml HTTP 请求获取访问令牌

  28. 28

    护照-Node.js不返回刷新令牌

  29. 29

    护照-Node.js不返回刷新令牌

热门标签

归档