• 解决Shiro第一次重定向url带有jsessionid导致400错误


    在Shiro进行第一次重定向时,会在url后携带jsessionid,这会导致400错误(无法找到该网页)。
    原因在于ShiroHttpServletResponse配置类的doIsEncodeable当中,会将url自动拼接jsessionid。

    解决办法:

    1. 在Shiro的配置类中的sessionManager()方法中,将sessionIdUrlRewritingEnabled属性设置为false。该方法返回一个DefaultWebSessionManager实例。
    2. 将上面方法返回的实例设置为DefaultWebSecurityManager实例的sessionManager。

    代码如下:

    @Bean
    public SecurityManager securityManager() {
    	DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
    	securityManager.setSessionManager(sessionManager());
    	securityManager.setRealm(myShiroRealm());
    	//将cookie管理器交给SecurityManager进行管理
    	securityManager.setRememberMeManager(rememberMeManager());
    	return securityManager;
    }
    
    @Bean
    public DefaultWebSessionManager sessionManager() {
    	DefaultWebSessionManager sessionManager = new DefaultWebSessionManager();
    	sessionManager.setSessionIdUrlRewritingEnabled(false);
    	return sessionManager;
    }
    
    计算机研狗一只
  • 相关阅读:
    经典机器学习算法总结
    从0开始学Python---01
    Android-Canvas.save() Canvas.restore() 总结
    Android-属性动画原理总结
    设计模式-外观模式
    设计模式-模板方法
    设计模式-装饰者模式
    设计模式-策略模式
    设计模式-工厂方法模式
    设计模式-简单工厂模式
  • 原文地址:https://www.cnblogs.com/xiepl1997/p/14423688.html
Copyright © 2020-2023  润新知