express-session使用redis遇到的坑。get无法取到值。

const passport = require("passport")
const session = require("express-session")
let RedisStore = require("connect-redis")(session)
// 下面的legacyMode: true一定不要忘记了,重点
let redisClient = createClient({ url: 'redis://10.86.10.41:6379/0', legacyMode: true })

redisClient.on('error', (err) => console.log('Redis Client Error', err));

main.ts里面加入。legacyMode: true
我是在passport里面做了验证。请按照一下写。

  // 使用session
  app.use(
    session({
      secret: 'keyboard cat', name: 'value', cookie: { maxAge: 1000 * 60 }, resave: false, saveUninitialized: false, store: new RedisStore({ client: redisClient, prefix: 'session:' }), genid: function (req) {
        // @ts-ignore
        return uuid.v4() // use UUIDs for session IDs
      },
    }),

local.strategy.ts

   // 把登录信息传到session里面,这点很重要,没下面的save方法,困扰1周以上。
    req.session.userinfo = loginUser;
    await new Promise(async (resolve, reject) => {
      resolve(req.session.save(() => {
        console.log('初始化session设置——————————————————————————————————');
        // await new Promise(async (resolve, reject) => {
        //   resolve(req.session.userinfo = loginUser)
        // })
        // will have a new session here
      }))
    })

custom.strategy.ts定义的验证session策略,

import { Injectable, Request, UnauthorizedException } from "@nestjs/common";
import { PassportStrategy } from "@nestjs/passport";
import { Strategy } from "passport-custom";
import { createClient } from "redis";
import { promisify } from "util";




@Injectable()
export class CustomStrategy extends PassportStrategy(Strategy) {
    async validate(@Request() req): Promise<any> {

        let redisClient = createClient({ url: 'redis://10.86.10.41:6379/0' })
        // 注意,passport的session数据结构,使用req.session.passport.user来访问 user session
        const sessionId: any = req.sessionID;
        console.log(req.session.userinfo)
        console.log(sessionId)
        let userinfo: any;
        // userinfo = req.session.userinfo;
        await redisClient.connect();
        userinfo = await redisClient.get(`session:${sessionId}`);
        console.log('####################');
        console.log(userinfo);
        if (!userinfo) {
            throw new UnauthorizedException();
        }
        return userinfo;
    }
}

全网第一份,欢迎交流

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Session Data Redis 是 Spring Session 提供的一种基于 Redis 的分布式会话管理方案。它可以将用户的会话信息存储在 Redis 中,实现分布式场景下的会话共享。 使用 Spring Session Data Redis 需要进行以下步骤: 1. 添加 Redis 依赖 在项目的 pom.xml 文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> </dependency> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> </dependency> ``` 2. 配置 Redis 连接 在 Spring Boot 应用的配置文件中,添加 Redis 的连接配置: ```yaml spring: redis: host: localhost port: 6379 ``` 3. 启用 Spring Session 在 Spring Boot 应用的启动类上添加 @EnableRedisHttpSession 注解,启用 Spring Session: ```java @SpringBootApplication @EnableRedisHttpSession public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 4. 使用 Spring Session 在需要获取当前用户的会话信息时,注入 HttpSession 对象即可: ```java @Controller public class MyController { @GetMapping("/hello") public String hello(HttpSession session) { String username = (String) session.getAttribute("username"); return "Hello, " + username + "!"; } } ``` Spring Session Data Redis 还支持一些高级特性,如会话过期时间、会话销毁监听器等。需要了解更多详情,请参考官方文档。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值