Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/gwt/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/visual-studio-code/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Session Shiro。没有id为的会话_Session_Gwt_Shiro_Subject - Fatal编程技术网

Session Shiro。没有id为的会话

Session Shiro。没有id为的会话,session,gwt,shiro,subject,Session,Gwt,Shiro,Subject,我正在为GWT webapp使用shiro-1.2.3。我能够配置用户的登录过程;然而,我需要一些关于shiro注销过程的帮助。webapp是通过tomcat部署的,它为不同的用户创建新的实例。因此,例如,当两个用户登录时,shiro创建了两个会话id;但是,当我单击“注销”按钮时,它将调用subject.logout()函数注销用户,因为某种原因,Shiro似乎只跟踪一个会话(上次登录的用户)。如果只有一个用户登录,它将成功注销;但是,当注销多个时,我得到的是: 原因:org.apache.s

我正在为GWT webapp使用shiro-1.2.3。我能够配置用户的登录过程;然而,我需要一些关于shiro注销过程的帮助。webapp是通过tomcat部署的,它为不同的用户创建新的实例。因此,例如,当两个用户登录时,shiro创建了两个会话id;但是,当我单击“注销”按钮时,它将调用subject.logout()函数注销用户,因为某种原因,Shiro似乎只跟踪一个会话(上次登录的用户)。如果只有一个用户登录,它将成功注销;但是,当注销多个时,我得到的是:

原因:org.apache.shiro.session.UnknownSessionException:没有id为[f5b7c3bf-2c53-40e9-a707-37f4265970aa]的会话 位于org.apache.shiro.session.mgt.eis.AbstractSessionDAO.readSession(AbstractSessionDAO.java:170) 位于org.apache.shiro.session.mgt.DefaultSessionManager.retrieveSessionFromDataSource(DefaultSessionManager.java:236) 位于org.apache.shiro.session.mgt.DefaultSessionManager.retrieveSession(DefaultSessionManager.java:222) 位于org.apache.shiro.session.mgt.AbstractValidatingSessionManager.doGetSession(AbstractValidatingSessionManager.java:118) 位于org.apache.shiro.session.mgt.AbstractNativeSessionManager.lookupSession(AbstractNativeSessionManager.java:105) 位于org.apache.shiro.session.mgt.AbstractNativeSessionManager.lookupRequiredSession(AbstractNativeSessionManager.java:109) 位于org.apache.shiro.session.mgt.AbstractNativeSessionManager.getAttribute(AbstractNativeSessionManager.java:206) 位于org.apache.shiro.session.mgt.DelegatingSession.getAttribute(DelegatingSession.java:141) 位于org.apache.shiro.session.ProxiedSession.getAttribute(ProxiedSession.java:121) 位于org.apache.shiro.session.ProxiedSession.getAttribute(ProxiedSession.java:121) 位于org.apache.shiro.session.ProxiedSession.getAttribute(ProxiedSession.java:121) 位于com.factorlab.security.FactorlabDelegatingSubject.getUser(FactorlabDelegatingSubject.java:34) 位于com.factorlab.security.FactorlabDelegatingSubject.getUser(FactorlabDelegatingSubject.java:10) 位于com.factorlab.persistence.AbstractEntityDao.getCurrentUser(AbstractEntityDao.java:227) 位于com.factorlab.persistence.AbstractEntityDao.fireEvent(AbstractEntityDao.java:215) 在com.factorlab.persistence.AbstractEntityDao.saveOrUpdate(AbstractEntityDao.java:190)上 在com.factorlab.persistence.AbstractEntityDao.saveOrUpdate(AbstractEntityDao.java:177)上 在com.factorlab.persistence.AbstractEntityDao.saveOrUpdate(AbstractEntityDao.java:38)上 位于sun.reflect.GeneratedMethodAccessor106.invoke(未知源) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中 位于java.lang.reflect.Method.invoke(Method.java:616) 位于org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:318) 位于org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:196) 位于$Proxy72.saveOrUpdate(未知来源) 访问com.factorlab.observations.sales.OpportunityScoreUpdateServiceImpl.receiveOpportunityEvent(OpportunityScoreUpdateServiceImpl.java:83) 位于sun.reflect.GeneratedMethodAccessor103.invoke(未知源) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中 位于java.lang.reflect.Method.invoke(Method.java:616) 位于org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:318) 位于org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:150)上 位于org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110) 位于org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:172) 位于org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202) 在$Proxy76.receiveOpportunityEvent(未知来源) 位于sun.reflect.GeneratedMethodAccessor102.invoke(未知源) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中 位于java.lang.reflect.Method.invoke(Method.java:616) 位于org.springframework.expression.spel.support.ReflectiveMethodExecutor.execute(ReflectiveMethodExecutor.java:69) 位于org.springframework.expression.spel.ast.MethodReference.getValueInternal(MethodReference.java:84) 位于org.springframework.expression.spel.ast.CompoundExpression.getValueInternal(CompoundExpression.java:57) 位于org.springframework.expression.spel.ast.SpelNodeImpl.getTypedValue(SpelNodeImpl.java:102) 位于org.springframework.expression.spel.standard.SpelExpression.getValue(SpelExpression.java:102) 位于org.springframework.integration.util.AbstractExpressionEvaluator.evaluateExpression(AbstractExpressionEvaluator.java:126) 位于org.springframework.integration.util.MessaginMethodInvokerHelper.processInternal(MessaginMethodInvokerHelper.java:227) 位于org.springframework.integration.util.MessaginMethodInvokerHelper.process(MessaginMethodInvokerHelper.java:127) 位于org.springframework.integration.handler.MethodInvokingMessageProcessor.processMessage(MethodInvokingMessageProcessor.java:73) ... 49多

我也尝试过使用EhCache管理器

对于登录,我使用的信息与shiro的10分钟教程中显示的相同


谢谢您的时间。

Shiro可以处理多个会话,所以一定是出了什么问题。登录会话是否来自两个完全不同的浏览器实例?您也可以显示您的登录代码吗?谢谢您的回复。我也遵循同样的方法
**Shiro.ini**
[main]
myRealm=com.java.gwt.server.auth.MyRealm
myCacheManager = org.apache.shiro.cache.MemoryConstrainedCacheManager
securityManager.cacheManager = $myCacheManager 
securityManager.sessionManager.globalSessionTimeout = 9000000