97 # session

koa 里的 cookie 用法

koa 里内置了设置 cookie 的方法

npm init -y
npm i koa @koa/router

用法:

const Koa = require("koa");
const Router = require("@koa/router");
const crypto = require("crypto");

const app = new Koa();
let router = new Router();
app.use(router.routes());

app.keys = ["kaimo"];

router.get("/visit", async (ctx, next) => {
    let visit = ctx.cookies.get("visit") || 0;
    visit++;
    ctx.cookies.set("visit", `${visit}`, {
        httpOnly: true,
        signed: true
    });
    ctx.body = `你当前访问次数${visit},签名:${crypto.createHmac("sha1", "kaimo").update(`visit=${visit}`).digest("base64")}`;
});

app.listen(3000);

console.log("Server running at http://127.0.0.1:3000/");

97 # session_第1张图片

session

  • session 基于 cookie 的,通过 cookie 的机制,制造一个服务端存储的空间
  • session 比 cookie 安全,每次重启服务会丢失,可以用 redis 来存储 session

办卡例子:给一个固定的卡号

npm i uuid
const Koa = require("koa");
const Router = require("@koa/router");
const uuid = require("uuid");

const app = new Koa();
let router = new Router();
app.use(router.routes());

app.keys = ["kaimo"];

const session = {};
const cardName = "kaimo.sid"; // 卡的名字,标识店铺名

router.get("/visit", async (ctx, next) => {
    let cardId = ctx.cookies.get(cardName);
    if (cardId && session[cardId]) {
        session[cardId].count--;
        ctx.body = `你有${session[cardId].count}次机会`;
    } else {
        let cardId = uuid.v4();
        session[cardId] = { count: 3 };
        ctx.cookies.set(cardName, cardId);
        ctx.body = `你有${session[cardId].count}次机会`;
    }
});

app.listen(3000);

console.log("Server running at http://127.0.0.1:3000/");

97 # session_第2张图片

koa-session 用法

Koa 的简单会话中间件。默认为基于 Cookie 的会话并支持外部存储。

https://www.npmjs.com/package/koa-session

npm i koa-session
const Koa = require("koa");
const Router = require("@koa/router");
const session = require("koa-session");

const app = new Koa();
let router = new Router();
app.use(session({}, app));
app.use(router.routes());

app.keys = ["kaimo"];

router.get("/visit", async (ctx, next) => {
    ctx.session.visit = ctx.session.visit || 0;
    ctx.session.visit++;
    ctx.body = `你有${ctx.session.visit}次机会`;
});

app.listen(3000);

console.log("Server running at http://127.0.0.1:3000/");

97 # session_第3张图片

你可能感兴趣的:(Node,/,Node,框架,前端工程架构,koa,koa-cookie,koa-session,session)