将登陆信息等重要信息存放为session、其他信息如果需要保留,可以放在cookie中
const Koa = require('koa');
const app = new Koa();
const Router = require('koa-router');
const router = new Router();
const bodyParser = require('koa-bodyparser');
const session = require('./koa-session');
app.keys = ['session-secret']; // 设置会话密钥,用于加密会话数据
app.use(session(app)); // 使用koa-session中间件
app.use(bodyParser());
router.get('/login', async (ctx) => {
ctx.body = `
<form action="/login" method="post">
<input type="text" name="username" />
<input type="submit" value="提交" />
</form>
`;
});
router.post('/login', async (ctx) => {
ctx.session.username = ctx.request.body.username; // 将用户名存储在会话中
ctx.redirect('/user');
});
router.get('/user', async (ctx) => {
if (ctx.session.username) {
ctx.body = ctx.session.username; // 从会话中获取用户名
} else {
return ctx.redirect('/login');
}
});
app.use(router.routes());
app.listen(3000, () => {
console.log('Server is running at http://localhost:3000');
});
const crypto = require('crypto');
function generateSessionId() {
return crypto.randomBytes(16).toString('hex');
}
function session() {
const sessionStore = {};
return async (ctx, next) => {
let sessionId = ctx.cookies.get('sessionId');
if (!sessionId || !sessionStore[sessionId]) {
sessionId = generateSessionId();
sessionStore[sessionId] = {};
ctx.cookies.set('sessionId', sessionId, {
httpOnly: true
});
}
ctx.session = sessionStore[sessionId];
await next();
};
}
module.exports = session;