1.app.jsjavascript
/** * koa 中 session 的使用 * 一、npm install koa-session --save * 二、const session = require('koa-session'); * 三、app.keys = ['some secret hurr']; * const CONFIG = { * key: 'koa:sess', * maxAge: 86400000, * overwrite: true, * httpOnly: true, * signed: true, * rolling: false, * renew: false * } * * 四、设置 session * ctx.session.username = '张三'; * 五、获取 session * ctx.session.username */ // 引入模块 const Koa = require('koa'); const router = require('koa-router')(); /*引入是实例化路由 推荐*/ const render = require('koa-art-template'); const path = require('path'); const session = require('koa-session'); // 实例化 let app = new Koa(); // 配置 koa-art-template 模板引擎 render(app, { root: path.join(__dirname, 'views'), // 视图的位置 extname: '.html', // 后缀名 debug: process.env.NODE_ENV !== 'production' // 是否开启调试模式 }) // 配置session的中间件 app.keys = ['some secret hurr']; /** cookie的签名 */ const CONFIG = { key: 'koa:sess', /** 默认 */ maxAge: 86400000, /** cookie的过时时间 【须要修改】*/ overwrite: true, /** (boolean) can overwrite or not (default true) 没有效果 默认*/ httpOnly: true, /** true表示只有服务器端能够获取cookie*/ signed: true, /** 默认 签名 */ rolling: false, /** 在每次请求时强行设置 cookie,这将重置 cookie 过时时间(默认:false) 【须要修改】*/ renew: true, /** (boolean) renew session when session is nearly expired 【须要修改】*/ } app.use(session(CONFIG, app)); router.get('/', async (ctx) => { // 获取session console.log(ctx.session.userinfo); await ctx.render('index', { list: { name: '张三' } }); }) router.get('/news', async (ctx) => { // 获取session console.log(ctx.session.userinfo); ctx.body = '新闻页面'; }) router.get('/login', async (ctx) => { // 设置session ctx.session.userinfo = '张三'; ctx.body = '登陆成功'; }) app.use(router.routes()); app.use(router.allowedMethods()); app.listen(3000);
.html