在Spring Security 3.1上限制为1后,会话仍处于活动状态

如何解决在Spring Security 3.1上限制为1后,会话仍处于活动状态

所以我有Spring Security 3.1,并且我将并发设置为max-sessions = 1和exceptionIfMaxMaxumExceeded =“ true”,并且它可以正常工作。当我尝试使用第二个浏览器登录时,会给我一个例外。

现在,当我使用第二个浏览器登录时,我希望它允许我登录并过期/关闭上一个会话(第一个浏览器)。我将“ exceptionIfMaximumExceeded”更改为false,它只允许我使用第二个浏览器登录,但是当我使用第一个浏览器时,仍然可以在不同的页面中移动。

我有以下文件。

LoginController.java

...
@Inject
    @Qualifier("sas")
    private SessionAuthenticationStrategy sessionAuthenticationStrategy;
...

@RequestMapping
    public String show(Map<String,Object> model,HttpServletRequest request,HttpServletResponse response) 
    {
        // clear any session data before asking for login credentials
        HttpSession session = request.getSession(false);
        if (session != null)
            session.invalidate();
...
try{
...
            sessionAuthenticationStrategy.onAuthentication(result,request,response);
...}catch(Exception ex){...}
}

spring-security.xml

<http use-expressions="true">
        <access-denied-handler error-page="/login.page" />
        <intercept-url pattern="/login.page" access="permitAll" />
        <intercept-url pattern="/*.page" access="isAuthenticated()" />
        <intercept-url pattern="/*.json" access="isAuthenticated()" />

        <form-login login-page="/login.page" authentication-failure-url="/login.page" />
        <logout logout-url="/logout" logout-success-url="/login.page" invalidate-session="true" />
        <session-management session-authentication-strategy-ref="sas" />
        <session-management>
            <concurrency-control expired-url="/login.page?expired" />
        </session-management>
        
    </http>

    
    <authentication-manager alias="authenticationManager">

        <authentication-provider user-service-ref='ApplicationAuthenticationProvider'>
            <password-encoder hash="sha-256" />
        </authentication-provider>

    </authentication-manager>
    <beans:bean id="concurrencyFilter" class="org.springframework.security.web.session.ConcurrentSessionFilter">
        <beans:constructor-arg name="sessionRegistry" ref="sessionRegistry" />
        <beans:constructor-arg name="expiredUrl" value="/login.page?expired" />
    </beans:bean>

    <beans:bean id="sessionRegistry" class="org.springframework.security.core.session.SessionRegistryImpl" />
    <beans:bean id="sessionFixation" class="org.springframework.security.web.authentication.session.SessionFixationProtectionStrategy">
        <beans:property name="migrateSessionAttributes" value="false" />
    </beans:bean>
    
    <beans:bean id="sas" class="org.springframework.security.web.authentication.session.ConcurrentSessionControlStrategy">
        <beans:constructor-arg name="sessionRegistry" ref="sessionRegistry" />
        <beans:property name="maximumSessions" value="1" />
        <beans:property name="exceptionIfMaximumExceeded" value="false" />
        <beans:property name="alwaysCreateSession" value="true" />
        <beans:property name="migrateSessionAttributes" value="false" />
    </beans:bean>

web.xml

<!-- Creates the Spring Container shared by all Servlets and Filters -->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>
    <listener>
        <listener-class>
          org.springframework.security.web.session.HttpSessionEventPublisher
        </listener-class>
    </listener>

applicationContext-custom.xml

<!-- Session Information Proxy -->
    <bean id="SessionModel" class="com.objectwave.session.SessionModelImpl" scope="session">
        <!-- this next element effects the proxying of the surrounding bean -->
        <aop:scoped-proxy proxy-target-class="false" />
    </bean>

我仅粘贴了xml文件的部分代码。我在xml Bean上尝试了不同的参数,但是不,它根本不起作用。

我阅读了一些有关过滤器的内容,但不确定如何工作。

此外,我已经在线调试了代码和LoginController

sessionAuthenticationStrategy.onAuthentication(result,response);

看起来好像它在上一个会话(浏览器1)中到期了,但是当我进入浏览器一时,它的工作就像什么都没发生一样(而且我曾经尝试调试,并且会话没有说任何有关过期的信息)

登录前端是自定义的(我什至不确定不自定义的外观!)

大多数(如果不是全部)配置都是通过xml文件完成的。

谢谢!

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-