在 Koa 中设置多个 cookie 头其实是比较直接的。Koa 内置的 ctx.cookies.set(name, value, [options])
方法使得在服务端处理 cookie 变得非常简单。要设置多个 cookie,你只需多次调用这个方法即可。
下面是一个具体的例子,展示在一个简单的 Koa 应用中如何设置多个 cookie:
javascriptconst Koa = require('koa'); const app = new Koa(); app.use(async ctx => { // 设置第一个 cookie ctx.cookies.set('username', 'JohnDoe', { httpOnly: true, // 增强安全性,使 JavaScript 无法读取该 cookie expires: new Date(Date.now() + 24 * 60 * 60 * 1000) // 设置过期时间为一天后 }); // 设置第二个 cookie ctx.cookies.set('session_id', 'xyz123', { secure: true, // 只在 HTTPS 连接中发送 maxAge: 3600000 // 设置最大年龄为 1 小时 }); ctx.body = 'Cookies are set.'; }); app.listen(3000);
在上述代码中,我们创建了一个 Koa 应用,并在中间件中设置了两个 cookie。每个 ctx.cookies.set
调用设置了一个 cookie,你可以根据需要来设置特定的选项,如 httpOnly
、expires
、secure
和 maxAge
等。
总的来说,设置多个 cookie 只是简单地多次调用 ctx.cookies.set
方法,并通过选项定制每个 cookie 的行为。这种方式让我们可以灵活地处理多个 cookie,并且可以根据应用的安全需求来配置每个 cookie 的选项。
2024年6月29日 12:07 回复