node: 跨越请求携带cookie问题

在做node中转服务时,将前端访问的接口转发到java后端,需要用到session辨别前端访问者的身份,但是在实现过程中,发现前端每次请求接口设置session 时,是成功的,

req.session.isDemo = true;

但是在另外的接口读取中session 时 都是undefine

console.log( req.session.isDemo ) //  undefine

刚查文档时  说需要将 session 设置配置在 app.user('/')之前 修改了不成功 不过 session配置确实必须配置在app.user('/')之前

var createError = require('http-errors');
var express = require('express');
var path = require('path');
var session = require("express-session")
var cookieParser = require('cookie-parser');
var logger = require('morgan');
var bodyParser = require('body-parser')
var fs = require('fs')


var app = express();
// 设置cookie和session  秘钥必须相同
app.use(cookieParser("sessiontest"));
// 配置session
app.use(session({
    secret:"sessiontest", //设置签名秘钥 内容可以任意填写
    cookie:{ maxAge:1000*60*60*24 }, //设置cookie的过期时间,例:80s后    session和相应的cookie失效过期
    resave:true, //强制保存,如果session没有被修改也要重新保存
    saveUninitialized:true //如果原先没有session那么久设置,否则不设置
}))


// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');


//设置跨域访问
app.all('*', function (req, res, next) {
    res.header('Access-Control-Allow-Origin', '*');
    res.header('Access-Control-Allow-Headers', 'Content-Type, Content-Length, Authorization, Accept, X-Requested-With , yourHeaderFeild');
    res.header('Access-Control-Allow-Methods', 'PUT, POST, GET, DELETE, OPTIONS');
    if (req.method == 'OPTIONS') {
        res.send(200);
    } else {
        next();
    }
});



// catch 404 and forward to error handler
app.use(function (req, res, next) {
    next(createError(404));
});

// error handler
app.use(function (err, req, res, next) {
    // set locals, only providing error in development
    res.locals.message = err.message;
    res.locals.error = req.app.get('env') === 'development' ? err : {};
    // render the error page
    res.status(err.status || 500);
    res.render('error');
});

module.exports = app;


 

后来发现  在前端接口请求时,node端每次都返回了一个新的cookie , 当再次请求后端时  通过新cookie匹配session时,每次都匹配到新的session。

解决参考文档 :  原文链接 https://www.cnblogs.com/nuccch/p/7875189.html 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值