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

豪尔赫·米兰达

我在使用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。登录后,每次通过中间件iAuthenticated调用服务器时,我进行的每次调用也是错误的!!!但是,奇怪的是,如果我尝试再次登录,则isAuthenticated为true。

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

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

豪尔赫·米兰达

似乎与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

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

来自分类Dev

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

来自分类Dev

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

来自分类Dev

使用ajax更新时,无法从summernote获得价值

来自分类Dev

使用Express 4 Router无法获得Content-Type标头

来自分类Dev

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

来自分类Dev

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

来自分类Dev

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

来自分类Dev

在Sails.js下使用SSL时,Passport.js无法初始化

来自分类Dev

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

来自分类Dev

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

来自分类Dev

使用AJAX(jQuery Mobile)时无法使用Javascript

来自分类Dev

Node.js抛出无法使用Express获得/

来自分类Dev

使用Vue.js和laravel / passport和GuzzleHttp时无法同时获取令牌和用户数据

来自分类Dev

单击提交按钮时,无法使用jquery / AJAX提交表单

来自分类Dev

使用AJAX,Slim和PHP时无法获取JSON数据

来自分类Dev

$ .ajax在使用fullcalendar js时无法正常工作吗?

来自分类Dev

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

来自分类Dev

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

来自分类Dev

ExpressJS:无法使用passport.js登录

来自分类Dev

Express + Passport:每次保存代码时,要求用户重置

来自分类Dev

为什么做ajax时无法获得readyState 3

来自分类Dev

使用Fetch API在Laravel中提取数据时,$ request-> ajax()无法检测到ajax请求

来自分类Dev

使用Hibernate Spatial时无法获得连接

来自分类Dev

使用 delta 时无法获得开放扩展

来自分类Dev

使用Passport验证Express应用-Express.js Passport.js

来自分类Dev

使用req.params作为passport.js中passport.authenticate()的输入(使用Express 4.0)

Related 相关文章

  1. 1

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

  2. 2

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

  3. 3

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

  4. 4

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

  5. 5

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

  6. 6

    使用ajax更新时,无法从summernote获得价值

  7. 7

    使用Express 4 Router无法获得Content-Type标头

  8. 8

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

  9. 9

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

  10. 10

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

  11. 11

    在Sails.js下使用SSL时,Passport.js无法初始化

  12. 12

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

  13. 13

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

  14. 14

    使用AJAX(jQuery Mobile)时无法使用Javascript

  15. 15

    Node.js抛出无法使用Express获得/

  16. 16

    使用Vue.js和laravel / passport和GuzzleHttp时无法同时获取令牌和用户数据

  17. 17

    单击提交按钮时,无法使用jquery / AJAX提交表单

  18. 18

    使用AJAX,Slim和PHP时无法获取JSON数据

  19. 19

    $ .ajax在使用fullcalendar js时无法正常工作吗?

  20. 20

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

  21. 21

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

  22. 22

    ExpressJS:无法使用passport.js登录

  23. 23

    Express + Passport:每次保存代码时,要求用户重置

  24. 24

    为什么做ajax时无法获得readyState 3

  25. 25

    使用Fetch API在Laravel中提取数据时,$ request-> ajax()无法检测到ajax请求

  26. 26

    使用Hibernate Spatial时无法获得连接

  27. 27

    使用 delta 时无法获得开放扩展

  28. 28

    使用Passport验证Express应用-Express.js Passport.js

  29. 29

    使用req.params作为passport.js中passport.authenticate()的输入(使用Express 4.0)

热门标签

归档