2

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

原因:org.apache.shiro.session.UnknownSessionException:org.apache.shiro.session.mgt.eis.AbstractSessionDAO.readSession(AbstractSessionDAO.java :170) 在 org.apache.shiro.session.mgt.DefaultSessionManager.retrieveSession(DefaultSessionManager.java:222) 在 org.apache.shiro.session.mgt.DefaultSessionManager.retrieveSessionFromDataSource(DefaultSessionManager.java:236) 在 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。 org.apache 上的lookupRequiredSession(AbstractNativeSessionManager.java:109)。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。持久性.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(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:616) at org。 springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:318) at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:196) at $Proxy72.saveOrUpdate(Unknown Source) at com.factorlab.observations .sales.OpportunityScoreUpdateServiceImpl。在 sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 在 java.lang.reflect.Method.invoke(Method.java: 616) 在 org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:183) 在 org.springframework.aop.framework.ReflectiveMethodInvocation 的 org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:318) .proceed(ReflectiveMethodInvocation.java:150) 在 org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110) 在 org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172) at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:202) at $Proxy76.receiveOpportunityEvent(Unknown Source) at sun.reflect.GeneratedMethodAccessor102.invoke(Unknown Source) at 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) at org.springframework.integration.util.AbstractExpressionEvaluator.evaluateExpression(AbstractExpressionEvaluator.java:126) at org.springframework.integration.util.MessagingMethodInvokerHelper.processInternal(MessagingMethodInvokerHelper. java:227) 在 org.springframework.integration.util.MessagingMethodInvokerHelper.process(MessagingMethodInvokerHelper.java:127) 在 org.springframework.integration.handler.MethodInvokingMessageProcessor.processMessage(MethodInvokingMessageProcessor.java:73) ... 49 更多MessagingMethodInvokerHelper.processInternal(MessagingMethodInvokerHelper.java:227) at org.springframework.integration.util.MessagingMethodInvokerHelper.process(MessagingMethodInvokerHelper.java:127) at org.springframework.integration.handler.MethodInvokingMessageProcessor.processMessage(MethodInvokingMessageProcessor.java:73) .. . 49 更多MessagingMethodInvokerHelper.processInternal(MessagingMethodInvokerHelper.java:227) at org.springframework.integration.util.MessagingMethodInvokerHelper.process(MessagingMethodInvokerHelper.java:127) at org.springframework.integration.handler.MethodInvokingMessageProcessor.processMessage(MethodInvokingMessageProcessor.java:73) .. . 49 更多

**Shiro.ini**
[main]
myRealm=com.java.gwt.server.auth.MyRealm
myCacheManager = org.apache.shiro.cache.MemoryConstrainedCacheManager
securityManager.cacheManager = $myCacheManager 
securityManager.sessionManager.globalSessionTimeout = 9000000

我也尝试过使用 EhCache 管理器。

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

谢谢你的时间。

4

0 回答 0