koa-web-session
v1.0.3
Published
koa-web session
Downloads
2
Readme
使用说明
- 使用基本步骤请参考: 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');
};
- 访问: http://localhost:3000/session/login