13.Egg.js教程-Session的相关操作

目录
文章目录隐藏
  1. Session 的添加
  2. Session 的获取
  3. Session 是直接可以支持中文的
  4. Session 的删除
  5. Session 的相关项配置
  6. 总结

Cookie 和 Session 非常类似,Egg 中的 Session 就存储在 Cookie 中,但是 Session 比 Cookie 的安全性更高。所以在开发中经常使用 Cookie 来保存是否登录,而用 Session 来保存登录信息和用户信息。本文就学习一下 Session 的使用。

Session 的添加

在开发中你可以理解为不重要的,公开的信息都可以临时存在 Cookie 里,但是隐私重要的信息,可以存在 Session 里,并且只允许在服务端进行操作。

先来看一下如何添加一个 Session。打开/app/controller/mybj.js文件,在add()方法里编写。

ctx.session.username='mybj'

这时,我们到控制台看一下是否存储 session。
这时,我们到控制台看一下是否存储 session

Session 的获取

添加完成后,我们在index()方法里获取一下 session 并展示在页面上。

async index() {
  const { ctx } = this;

  //获取 Session
  const username= ctx.session.username

  await ctx.render(
    'mybj.html',{
      id:2021,
      name:'小红',
      age: 18,
      //赋值给模板
      username,
      skills:[
        '泰式按摩',
        '精油搓背',
        '水疗 SPA'
      ]
    })
}

在 Session 存在的情况下,我们已获得了 Session 的值,并且把获得的值发送给了模板。再到模板中修改模板,把值显示出来app/view/mybj.html

<h3><%=username%></h3>

这时,我们到浏览器中输入http://127.0.0.1:7001/my,然后点击增加 Cookie按钮,刷新页面后,可以在页面中看到出现mybj,说明已经添加 Session 并读取 Session 成功了。

添加 Session 并读取 Session 成功

这时候打开浏览器的控制台的Application标签,可以看到多了一个EGG_SESS的 Cookie,这个就是我们刚才存储的 Session 了。

Session 是直接可以支持中文的

比如现在我们要把 Session 中 username 的值换成中问的码云笔记,代码如下:

ctx.session.username='码云笔记前端博客'

删除所有 Cookie,然后再次点击增加 Cookie按钮,然后再次刷新按钮,页面显示出了码云笔记前端博客字样,说明中文的 Session 值也是完全可以使用的。

Session 的删除

删除 Session 非常简单,只需要把值设置为null就可以了。在del()方法中编写下面的代码。

ctx.session.username=null

这样就可以删除 session 了。这时候到浏览器中,可以先点击增加 Cookie按钮,再点击删除 Cookie按钮,可以看到Session也被删除掉了,页面中的值就消失掉了。

Session 的相关项配置

配置 Session 的一些选项,需要到config.default.js文件中进行配置。

config.session = {
    key :"PANG_SESS",   // 设置 Key 的默认值
    httpOnly:true,      // 设置服务端操作
    maxAge:1000*60  ,   // 设置最大有效时间
    renew: true,        // 页面有访问动作自动刷新 session 
}

总结

本文我们主要学习了 Egg 中 Session 的增删改查和配置相关的操作。

「点点赞赏,手留余香」

0

给作者打赏,鼓励TA抓紧创作!

微信微信 支付宝支付宝

还没有人赞赏,快来当第一个赞赏的人吧!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » 13.Egg.js教程-Session的相关操作

发表回复