基于SpringBoot,SpringSession和redis的会话共享

本文介绍如何使用Spring Session和Redis实现单点登录(SSO)功能。通过配置Spring Boot项目,利用Redis作为会话存储,并设置相应的会话配置,最终实现两个不同域名间的会话共享。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

安装redis

$ wget http://download.redis.io/releases/redis-4.0.1.tar.gz
$ tar xzf redis-4.0.1.tar.gz
$ cd redis-4.0.1
$ make
配置redis.conf,允许外部连接




使用IntelliJ IDEA创建Spring Boot工程,选择web, redis, session.

LoginController.java

package com.example.springsessiondemo;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;


@Controller
public class LoginController {

    @RequestMapping("/")
    @ResponseBody
    public String home(HttpServletRequest request, HttpServletResponse response) {
        HttpSession session = request.getSession();
        User user = (User) session.getAttribute("user");


        if (user == null){
            return "用好未登录" + session.getId();
        } else {
            return "用好已登录" + session.getId();
        }
    }

    @RequestMapping("/login")
    @ResponseBody
    public String login(HttpServletRequest request){
        User user = new User();
        user.setUsername("chf");
        user.setPassword("pass");
        request.getSession().setAttribute("user", user);

        return "登录成功 "  + request.getSession().getId();
    }
}


创建文件config.java

@Configuration
@ImportResource(locations={"classpath:spring.xml"})
public class Config {
}


配置文件application.yaml

server:
  port: 8000
spring:
  session:
    store-type: redis
  redis:
    host: 10.0.0.201
    port: 6379
    password:


配置文件spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

    <bean id="defaultCookieSerializer" class="org.springframework.session.web.http.DefaultCookieSerializer">
        <property name="domainName" value="example.com"/>
        <property name="cookieName" value="JSESSIONID"/>
        <property name="cookiePath" value="/" />
        <!-- <property name="domainNamePattern" value="^.+?\.(\w+\.[a-z]+)$"></property>-->
    </bean>

    <bean id="redisHttpSessionConfiguration" class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration">
        <property name="maxInactiveIntervalInSeconds" value="1800" />
        <property name="cookieSerializer" ref="defaultCookieSerializer"/>
    </bean>
</beans>

配置hosts文件

127.0.0.1 www.example.com
127.0.0.1 passport.example.com


运行程序,通过浏览器访问passport.example.com:8000



访问www.example.com:8000


JSESSIONID的内容相同,说明实现了会话共享。



接下来在passport进行登录



切换到www


一个简单的单点登录系统就实现了。

源代码工程

https://github.com/chenhaifeng2016/springsessiondemo

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值