使用AJAX时无法通过Passport + Express4认证

豪尔赫·米兰达(Jorge Miranda)

我在使用Passport时遇到了一个问题:调用我的自定义端点时,我无法检查用户是否已通过身份验证。

我已经通过以下方式配置了Express4应用程序:

app.use(morgan('dev')); // log every request to the console
app.use(cookieParser()); // read cookies (needed for auth)
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
// required for passport
app.use(session({ secret: 'secretphrase' })); // session secret
app.use(passport.initialize());
app.use(passport.session()); // persistent login sessions
app.use(checkAuth); // CHECK SESSION
app.use(flash()); // use connect-flash for flash messages stored in session
app.use(prepareRequests);

checkAuth()中间件具有以下代码:

var checkAuth = function(request, response, next) {

    console.log("------------");
    console.log("checkAuth user: " + request.session.passport.user);
    console.log("checkAuth isAuthenticated: " + request.isAuthenticated());
    next();
}

我第一次尝试使用护照登录时,isAuthenticated为false。一旦我登录,当我通过中间件通过isAuthenticated时,我对服务器的每次调用也是错误的!!!但是,奇怪的是,如果我尝试再次登录,则isAuthenticated为true。

这意味着只有我的AJAX调用返回isAuthenticated = false,但是当我进行表单发布或单击指向API的链接时,它返回true!然后存储会话,但不存储AJAX请求。

我做错了什么?Cookie是否没有通过?

豪尔赫·米兰达(Jorge Miranda)

似乎与Dropped.on.Caprica交谈可以帮助我找到解决方案...。

服务器已登录,并成功保存了会话。但是,然后,您必须在以下AJAX请求中传递Express创建的cookie(withCredentials = true)。如果您使用的是JQuery,请按照以下方式使用:

$.ajax({
    url: 'http://127.0.0.1:3003/users/me',
    type: 'GET',
    xhrFields: {
       withCredentials: true
    }}).done(function() {
      alert( "done" );
    });

如果您不是:

var request = window.XDomainRequest ? new XDomainRequest() : new XMLHttpRequest();      
var pda;
request.withCredentials = true;

然后,在每次调用时,在您的Node.JS服务器中,要求request.isAuthenticated()将返回正确的值!!!

其他提示:别忘了在Express响应中修改您的响应标头以允许凭据并指定来源,以使其在Chrome中起作用:

response.header("Access-Control-Allow-Credentials", "true");
response.header("Access-Control-Allow-Origin", "http://127.0.0.1:3008");

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

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

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

使用AJAX时Passport + Express4无法获得认证

来自分类Dev

Passport js + Express4。无法结束登录会话

来自分类Dev

Node.js:我怎样才能简单地使用express4获取请求主体?

来自分类Dev

我们可以将express4与underscore.js一起使用吗?

来自分类Dev

使用Express和Passport的Google令牌认证不起作用

来自分类Dev

为什么使用Socket.IO将NodeJS服务器(Sails)连接到另一个NodeJS Server(Express4)失败?

来自分类Dev

为什么使用Socket.IO将NodeJS服务器(Sails)连接到另一个NodeJS Server(Express4)失败?

来自分类Dev

停止express4中的中间件链

来自分类Dev

Express4:存储数据库实例

来自分类Dev

无法使用Passport.js和Express 4访问req.user

来自分类Dev

CAS 4-成功认证后无法检索LDAP组

来自分类Dev

Express4如何在单个模块中返回多个函数

来自分类Dev

Express4 app.get不要等待库调用继续

来自分类Dev

express4路由器跳过基本路由并直接转到子路由

来自分类Dev

通过GitHub部署时Express 4应用程序无法在Azure中运行

来自分类Dev

Ruby on Rails 4-使用什么认证gem?

来自分类Dev

使用通过Azure AD认证的Swagger的webapi时的“无效令牌”

来自分类Dev

令牌认证:无法认证

来自分类Dev

Express角色认证

来自分类Dev

在Express中使用jsonwebtoken时,passport.js的用途是什么

来自分类Dev

使用 Facebook 登录、Passport、Express、React 和 Node 时没有设置用户 cookie

来自分类Dev

Express Passport无法获取Facebook朋友列表

来自分类Dev

使用passport.js的微服务认证架构

来自分类Dev

Laravel Passport使用未经认证的Axios 401消耗自己的API

来自分类Dev

通过twitter4j库在Twitter中更新状态-401认证凭证...错误

来自分类Dev

通过IMEI认证的3g / 4g设备连接到SQL Server

来自分类Dev

使用Docker为Node,我基于Express的Node应用,MongoDb和NodeBB构建映像,并通过Passport连接

来自分类Dev

Passport 不调用认证策略

来自分类Dev

使用Spring Security无法通过LDAP认证到目录(Active Directory)

Related 相关文章

  1. 1

    使用AJAX时Passport + Express4无法获得认证

  2. 2

    Passport js + Express4。无法结束登录会话

  3. 3

    Node.js:我怎样才能简单地使用express4获取请求主体?

  4. 4

    我们可以将express4与underscore.js一起使用吗?

  5. 5

    使用Express和Passport的Google令牌认证不起作用

  6. 6

    为什么使用Socket.IO将NodeJS服务器(Sails)连接到另一个NodeJS Server(Express4)失败?

  7. 7

    为什么使用Socket.IO将NodeJS服务器(Sails)连接到另一个NodeJS Server(Express4)失败?

  8. 8

    停止express4中的中间件链

  9. 9

    Express4:存储数据库实例

  10. 10

    无法使用Passport.js和Express 4访问req.user

  11. 11

    CAS 4-成功认证后无法检索LDAP组

  12. 12

    Express4如何在单个模块中返回多个函数

  13. 13

    Express4 app.get不要等待库调用继续

  14. 14

    express4路由器跳过基本路由并直接转到子路由

  15. 15

    通过GitHub部署时Express 4应用程序无法在Azure中运行

  16. 16

    Ruby on Rails 4-使用什么认证gem?

  17. 17

    使用通过Azure AD认证的Swagger的webapi时的“无效令牌”

  18. 18

    令牌认证:无法认证

  19. 19

    Express角色认证

  20. 20

    在Express中使用jsonwebtoken时,passport.js的用途是什么

  21. 21

    使用 Facebook 登录、Passport、Express、React 和 Node 时没有设置用户 cookie

  22. 22

    Express Passport无法获取Facebook朋友列表

  23. 23

    使用passport.js的微服务认证架构

  24. 24

    Laravel Passport使用未经认证的Axios 401消耗自己的API

  25. 25

    通过twitter4j库在Twitter中更新状态-401认证凭证...错误

  26. 26

    通过IMEI认证的3g / 4g设备连接到SQL Server

  27. 27

    使用Docker为Node,我基于Express的Node应用,MongoDb和NodeBB构建映像,并通过Passport连接

  28. 28

    Passport 不调用认证策略

  29. 29

    使用Spring Security无法通过LDAP认证到目录(Active Directory)

热门标签

归档