我正在使用以koa为框架的nodejs,以及koa-session和koa-redis。
import Koa from 'koa';
...
import session from 'koa-session';
import redisStore from 'koa-redis';
const app = new Koa();
app.keys = ["cookieKeys"];
app.use(session({
maxAge: 5184000000,
store: redisStore({url: 'redis://localhost:6379'})
}, app));
...
const server = app.listen(1339, () => {
console.log(`Server listening on port: 1339`);
});
export default server;
现在可以设置ctx.session.key = "value";
并在Redis上获取ctx.sessios.key;
,因为已经建立了连接。
我如何在其他模块中访问在koa会话存储中使用的同一Redis客户端?现在,我正在创建一个新的连接:
import { Context, Next, Middleware } from 'koa';
import redis from 'koa-redis';
export default async (ctx: Context, next: Next): Promise<Middleware> => {
try {
return await next();
} catch (err) {
if (err.status !== 401) {
throw err;
}
const redisClient = await redis({url: 'redis://localhost:6379'}).client;
const tokenAccess = ctx.cookies.get('tokenAccess', {signed: true});
const tokenRefresh = ctx.session.tokenRefresh;
...
const isRefreshTokenRevoked = Number.isInteger(await redisClient.zrank('blacklist', tokenRefresh));
await redisClient.quit();
if (isRefreshTokenRevoked) {
throw err;
}
...
}
}
我在上下文ctx.session._sessCtx.store.client
中发现了此属性。为此目的使用此属性是否正确?
答案 0 :(得分:0)
我想我的问题跳得很低。我用db.js
文件重新编写了代码,然后将我的redis连接放在那里,例如:
import { redisURI } from './config';
import Redis from 'koa-redis';
export const redisStore = Redis({url: redisURI});
所以现在我可以导入此连接并在index.js
上重新利用:
import Koa from 'koa';
...
import session from 'koa-session';
import { redisStore } from './db';
//import redisStore from 'koa-redis';
const app = new Koa();
app.keys = ["cookieKeys"];
app.use(session({
maxAge: 5184000000,
store: redisStore
//store: redisStore({url: 'redis://localhost:6379'})
}, app));
...
const server = app.listen(1339, () => {
console.log(`Server listening on port: 1339`);
});
export default server;
已导入其他模块:
import { Context, Next, Middleware } from 'koa';
import { redisStore } from './db';
export default async (ctx: Context, next: Next): Promise<Middleware> => {
try {
return await next();
} catch (err) {
if (err.status !== 401) {
throw err;
}
//const redisClient = await redis({url: 'redis://localhost:6379'}).client;
const tokenAccess = ctx.cookies.get('tokenAccess', {signed: true});
const tokenRefresh = ctx.session.tokenRefresh;
...
const isRefreshTokenRevoked = Number.isInteger(await redisStore.client.zrank('blacklist', tokenRefresh));
//const isRefreshTokenRevoked = Number.isInteger(await redisClient.zrank('blacklist', tokenRefresh));
//await redisClient.quit();
if (isRefreshTokenRevoked) {
throw err;
}
...
}
}