NodeJS 中使用 express-session

环境:
ubuntu-18.04
NodeJS-v12.4.0
NPM-6.9.0

# 安装
sudo npm install express-session

注册 session

// 服务端 app.js
// 导入 session 模块
var app = express()
const session = require('express-session');
app.set('trust proxy', 1) // 信任代理
/**
 * session
 *  secret:  一个 String 类型的字符串,作为服务器端生成 session 的签名
 *  name:    保存在本地cookie的一个名字 默认connect.sid  可以不设置
 *  resave:  强制保存 session 即使它并没有变化,。默认为 true。建议设置成 false。
 *  rolling: 在每次请求时强行设置 cookie,这将重置 cookie 过期时间(默认:false)
 *  saveUninitialized: 强制将未初始化的 session 存储。默认值是true,建议设置成true
 *
 * cookie
 *  属性默认值: { path: '/', httpOnly: true, secure: false, maxAge: null }
 *  httpOnly: 属性禁止客户端JavaScript的访问,禁止后不能使用document.cookie
 *  secure:    https这样的情况才可以访问cookie
 *  maxAge:   单位毫秒,从设置cookie开始多少毫秒失效(如果maxAge和expires都设置了,最后设置的属性生效.)
 *  path:     路径,默认值为域名的根路径
 *  sameSite:  SameSite-cookies是一种机制,用于定义cookie如何跨域发送。
 */
app.use(session({
    secret: 'keyboard cat',
    name: 'xxxxID',
    resave: true,
    rolling: true,
    saveUninitialized: true,
    cookie: {
        secure: true,
        // domain: 'xxx.xxx.xxx.xxx:xxxx', // 域名
        path: '/'
        httpOnly: true,
        maxAge: 1800000
    }
}));

使用 session 保存数据

// 业务处理 Controller
(req, res) => {
    // ...
    req.session.user = result[0];
    req.session.isLogin = true;
    res.send({
        success: true,
        user: req.session.user,
        url: '/index'
    });
}

销毁 session 数据

(req, res) => {
    req.session.destroy(() => {
        res.redirect('login');
    });
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 最近总是想记录下每天的心情和感触,发现很棒的一点是,从每一页内容来看,几乎都是开心的,幸福的,所以就像跟小师傅说的...
    简单杜过阅读 1,313评论 0 0
  • 我在教室里上课,倒数四五排的样子,前面空了很多座位,我心不在焉的偶尔抬头看看黑板,课程名称:嵌入式系统设计。 在这...
    ParachuteChen阅读 1,228评论 0 0