1.0.3 • Published 3 years ago

koa-web-session v1.0.3

Weekly downloads
-
License
MIT
Repository
github
Last release
3 years ago

使用说明

  • 使用基本步骤请参考: koa-web
  • 新增session的支持,koa-session 数据保存到根目录的.cache中
  • koa-session默认保存到cookie中,这种情况并不安全
  • 但koa-session也提供了数据保存接口,koa-web-session简单的封装了下
  • koa-web-session启动时将自动清理过期的session数据文件

安装 koa-web-session

npm i koa-web
npm i koa-web-session

启动程序

const Koa = require("koa");
const KoaWeb = require('koa-web');
const KoaWebSession = require('koa-web-session');

const app = new Koa();

const config = {
  // session 将保存到 __dirname/.cache中
  path: __dirname,

  // session文件保存路径
  // sessionPath: __dirname,

  // cookie键名 默认: xweb
  // sessionKey: "xweb",

  // cookie过期时间, 默认 86400000 (一天)
  // sessionMaxAge: 86400000
};

KoaWebSession(app, config);

app.use(KoaWeb(config));

app.listen(3000, () => {
  console.log("server is running at http://localhost:3000");
});

session调用实例

创建html页面: /html/session/login.html

<html>
<head>
  <title>{% if login %}欢迎: {{ username }}{% else %}登录测试{% endif %}</title>
</head>
<body>
{% if login %}
  <div>欢迎: {{ username }}</div>
  <form action="login.logout" method="post">
    <div><input type="hidden" name="logout" value="true"></div>
    <div><input type="submit" value="退出"></div>
  </form>
{% else %}
  <form action="login.login" method="post">
    <div><input type="text" name="username"></div>
    <div><input type="text" name="password"></div>
    <div><input type="submit" value="登录"></div>
  </form>
{% endif %}
</body>
</html>

创建数据控制页面: /html/session/login.js

// html登录页面
module.exports.html = async hd => {
  if (hd.ctx.session.login) {
    hd.view({
      login: hd.ctx.session.login,
      username: hd.ctx.session.username
    });
  } else {
    hd.view({
      login: false
    });
  }
};

// 用户登录 账号: admin 密码: admin
module.exports.login = async (hd, data) => {
  if (!hd.isPost()) {
    return "数据提交错误!";
  }

  let username = data.username;
  let password = data.password;

  if (username !== 'admin' || password !== 'admin') {
    return "登录失败";
  }

  hd.ctx.session.login = true;
  hd.ctx.session.username = username;

  hd.ctx.status = 301;
  hd.ctx.redirect('/session/login');

  return "登录成功";
};

// 用户登出
module.exports.logout = async (hd, data) => {
  if (data.logout === 'true') {
    hd.ctx.session = null;
  }

  hd.ctx.status = 301;
  hd.ctx.redirect('/session/login');
};
1.0.2

3 years ago

1.0.3

3 years ago

1.0.1

3 years ago

1.0.0

3 years ago