繁体   English   中英

res.cookie(名称,值); 不设置 cookie (Express/NodeJs)

[英]res.cookie(name,value); Not setting cookie (Express/NodeJs)

我正在使用 NodeJs、Express Framework 和 Firebase 开发 Web 应用程序。 在客户端上使用 firebase 函数进行身份验证后,idToken 被发送到服务器,在那里创建会话 cookie,然后存储在 cookie 中。 但是, res.cookie 无法在客户端上存储 cookie。

客户端 auth.js 片段(所有 2 个都属于同一个 js 客户端文件)

//Log-in event start
$( "#log-form" ).submit(function( event ) {
        event.preventDefault();
        var email = document.getElementById('emailInput').value;
        var password = document.getElementById('passwordInput').value;
        firebase.auth().signInWithEmailAndPassword(email,password)
            .catch(function(error) {
                    var errorCode = error.code;
                    var errorMessage = error.message;
                    window.alert(errorMessage);
                    })
            .then(function(value) {
                    firebase.auth().currentUser.getIdToken(true)
                            .then(function(idToken) {
                                sendToken(idToken);
                                })
                            .catch(function(error) {
                                console.log(error.message);
                                });
                });
    });//end of log-in event


function sendToken(token)
{
    $.ajax({
            type: 'POST',
            url: '/users/authIn',
            data: {
                'token' : token
            },
            success: function(data){
                console.log(data);
            },
            error: function(errMsg)
                {
                    console.log(errMsg);

                }
        });

 }

服务器端路由/users.js 代码片段

router.post('/authIn', function (req, res, next) {
var token = req.body.token.toString();
var expiresIn=1000*60*60*24;
admin.auth().verifyIdToken(token)
    .then(function(decodedToken){
        firebase.auth().createSessionCookie(token,{expiresIn})
            .then(function(sessionCookie)
                  {
                    res.cookie('session', sessionCookie);
                    res.send("done");
                    })
            .catch(function(error)
                  {
                    res.send(error);

                    });
        res.redirect('/interfacePage');
        })//end of .then
    .catch(function(error){
        res.send(error);
        })
});

我一直试图让这个工作几天现在无济于事。 任何帮助将不胜感激。如果您的回答不仅仅是一个修复而是一个解决方法,请包含代码,因为我对 ajax/express 相当陌生,可能不熟悉某些术语/技术。

编辑:找到灵魂

代替:

 res.cookie('session', sessionCookie);
 res.send("done");

我需要使用:

res.setHeader('Cache-Control', 'private');
res.cookie('__session', sessionCookie);
res.send("done");

Firebase 允许使用名为“__session”的单个 cookie

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM