koa对cookie提供了很好的支持,在此基础上ThinkKoa进行了进一步的封装和简化:

项目中间件配置 config/middleware.js:

  1. config: { //中间件配置
  2. ...,
  3. cookie: {
  4. domain: '',
  5. path: '/',
  6. ...
  7. }
  8. }

控制器中使用

cookie(name[, value, option])

获取或者设置cookie值。options包括项

  • signed sign cookie 值
  • domain: '', // cookie所在的域名
  • path: '/', // cookie所在的路径
  • maxAge: 86400, // cookie有效时长
  • httpOnly: true, // 是否只用于http请求中获取
  • overwrite: false, // 是否允许重写
  • expires: new Date('2017-02-15') // cookie失效时间
  1. //获取cookie
  2. this.cookie('site');
  3. //设置cookie
  4. this.cookie('site', 'www.baidu.com');

如果options未传递,默认遵循项目中cookie的全局配置。

中间件及其他类中使用

ctx.cookie(name[, value, options = {}])

ThinkKoa扩展 think_cookie中间件

获取或者设置cookie值。options包括项

  • domain: '', // cookie所在的域名
  • path: '/', // cookie所在的路径
  • maxAge: 86400, // cookie有效时长
  • httpOnly: true, // 是否只用于http请求中获取
  • overwrite: false, // 是否允许重写
  • expires: new Date('2017-02-15') // cookie失效时间

如果options未传递,默认遵循项目中cookie的全局配置。

koa原生用法

ctx.cookies.get(name, [options])

koa原生

获取名为 name 带有 options 的 cookie:

signed 请求的 cookie 应该是被 signedkoa 使用 cookies 模块, options 被直接传递过去.

ctx.cookies.set(name, value, [options])

koa原生

设置 cookie name 为 value 带有 options:

  • signed sign cookie 值
  • domain: '', // cookie所在的域名
  • path: '/', // cookie所在的路径
  • maxAge: 86400, // cookie有效时长
  • httpOnly: true, // 是否只用于http请求中获取
  • overwrite: false, // 是否允许重写
  • expires: new Date('2017-02-15') // cookie失效时间

koa 使用 cookies 模块, options 被直接传递过去。注意原生写法,并不会自动传入项目配置,需要自行定义options