iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >koa2实现session的两种方式(基于Redis 和MySQL)
  • 541
分享到

koa2实现session的两种方式(基于Redis 和MySQL)

摘要

一.基于Mysql的实现方式 这种方式需要安装koa-session-minimal和koa-mysql-session两个依赖。 执行 npm install koa-session-minimal koa-mysql-session


	koa2实现session的两种方式(基于Redis 和MySQL)
[数据库教程]

一.基于Mysql的实现方式

这种方式需要安装koa-session-minimal和koa-mysql-session两个依赖。

执行

npm install koa-session-minimal koa-mysql-session

项目配置:

技术图片
const session = require(‘koa-session-minimal‘);  
const MysqlStore = require(‘koa-mysql-session‘);
const config = require(‘./config/default.js‘);  // 数据库配置
const Koa = require(‘koa‘);
const app = new Koa();

// session存储配置
const sessionMysqlConfig = {
  user: config.database.USERNAME,
  passWord: config.database.PASSWORD,
  database: config.database.DATABASE,
  host: config.database.HOST,
};

 // 配置session中间件
app.use(session({
  key: ‘USER_SID‘,
  store: new MysqlStore(sessionMysqlConfig)
}));
技术图片

 

这种方式会自动在数据库建立一个表:

技术图片

在浏览器的cookie中会生成一个以 USER_SID 为键的cookie。通过ctx的session属性可以修改更新删除session的值。

缺点是每次对session的操作需要查询数据库,比较耗时。

 

二、基于Redis的实现方式

主要用到了koa-session2和ioredis。

npm install koa-session2 ioredis

项目配置:

技术图片
// redis
const session = require("koa-session2");
const Store = require("./config/Store");

// 使用redis作为session存储
app.use(session({
  store: new Store(),
  key: "SESSIONID",  // default "koa:sess"
}));

config/Store.js

const Redis = require("ioredis");
const { Store } = require("koa-session2");
const redisConfig = require(‘./redis‘);
 
class RedisStore extends Store {
    constructor() {
        super();
        this.redis = new Redis(redisConfig);
    }
 
    async get(sid, ctx) {
        let data = await this.redis.get(`SESSION:${sid}`);
        return JSON.parse(data);
    }
 
    async set(session, { sid =  this.getID(24), maxAge = 1000000 } = {}, ctx) {
        try {
            // Use redis set EX to automatically drop expired sessions
            await this.redis.set(`SESSION:${sid}`, JSON.stringify(session), ‘EX‘, maxAge / 1000);
        } catch (e) {}
        return sid;
    }
 
    async destroy(sid, ctx) {
        return await this.redis.del(`SESSION:${sid}`);
    }
}
 
module.exports = RedisStore;
技术图片

技术图片

 

 这样,每次登陆就可以通过Redis来存储会话信息,由于Redis直接是运行在内存中的,因此速度会比较快。

通过get key 即可查看相应的session信息。

koa2实现session的两种方式(基于Redis 和MySQL)

原文地址:https://www.cnblogs.com/it-xiong/p/13451521.html

您可能感兴趣的文档:

--结束END--

本文标题: koa2实现session的两种方式(基于Redis 和MySQL)

本文链接: https://www.lsjlt.com/news/7769.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作