如何在快递+护照js中注销时删除cookie?

rom*_*mir 5 javascript cookies node.js express passport.js

我想“注销时删除 cookie”。我不能那样做。我用谷歌搜索答案,发现以下方法:

  1. 为 cookie 分配新的到期日期

    res.cookie('connect.sid', '', {expires: new Date(1), path: '/' });

  2. 使用以下行删除 cookie

    res.clearCookie('connect.sid', { path: '/' });

我分别尝试了两种方法,但它们不会删除 cookie。

这是我的代码:

路由.js

module.exports = function(app, passport, session){
    app.get('/', function(req, res)
    {
       res.render('index.ejs');
    });

    app.get('/login', function(req,res){
     res.render('login.ejs',{message:req.flash('loginMessage')});
    });


    app.get('/signup',checkRedirect , function(req, res) {
        res.render('signup.ejs',{message: req.flash('signupMessage')});
    });
    app.get('/profile', isLoggedIn, function(req,res) {
        res.render('profile.ejs', {
            user :req.user
        });
    });
    app.post('/signup', passport.authenticate('local-signup', {
        successRedirect : '/profile',
        failureRedirect : '/signup',
        failureFlash : true
    }));
    app.post('/login',  passport.authenticate('local-login', {

        successRedirect : '/profile',
        failureRedirect : '/login',
        failureFlash :true

    }));
app.get('/logout',function(req,res){
    res.cookie('connect.sid', '', {expires: new Date(1), path: '/' });
   req.logOut();
    res.clearCookie('connect.sid', { path: '/' });
    res.redirect('/');
});

function isLoggedIn(req, res, next){

    if(req.isAuthenticated())
      return next();

    console.log("hiii");
    res.redirect('/');
}
Run Code Online (Sandbox Code Playgroud)

};

服务器.js

    var express = require('express');
var app = express();
var port = process.env.PORT || 3000;
var mongoose = require('mongoose');
var passport = require('passport');
var flash=require('connect-flash');
var morgan=require('morgan');
var bodyParser = require('body-parser');
var cookieParser=require('cookie-parser');
//
var session=require('express-session');
var RedisStore = require('connect-redis')(session);
var redis   = require("redis");
var redis_client  = redis.createClient();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: true}));
var configDb=require('./config/database.js');
mongoose.connect(configDb.url);

require('./config/passport')(passport);

app.use(morgan('dev'));
app.use(cookieParser());
app.use(bodyParser());
app.set('view engine', 'ejs');


app.use(session({
    store: new RedisStore({
    host: '127.0.0.1',
    port: 6379,
    client: redis_client
}),
    secret : 'foo',
    resave: false,
    saveUninitialized: false
}));
app.use(function (req, res, next) {
    if (!req.session) {
        return next(new Error('oh no')); // handle error
    }
    next();
});


});

app.use(passport.initialize());
app.use(passport.session());
app.use(flash());

require('./app/routes')(app, passport, session);
app.listen(port, function(){
    console.log('server is at port' + port);
});
Run Code Online (Sandbox Code Playgroud)

小智 6

请试试这个:

router.get('/logout', function (req, res) {
  req.logOut();
  res.status(200).clearCookie('connect.sid', {
    path: '/'
  });
  req.session.destroy(function (err) {
    res.redirect('/');
  });
});
Run Code Online (Sandbox Code Playgroud)

  • 另外,我认为状态是多余的,正如另一个答案中提到的,因为重定向将其设置为 302。也不需要`path:'/'`。`clearCookie` 默认采用 `path:'/'` (2认同)

Sud*_*aur 2

您可以在注销路由中使用 req.session.destroy 来销毁会话,下面是参考代码:)

\n\n
app.get('/logout', function(req,res){\n req.logOut();\n req.session.destroy(function (err) {\n        res.redirect('/'); //Inside a callback\xe2\x80\xa6 bulletproof!\n    });\n});\n
Run Code Online (Sandbox Code Playgroud)\n