@Configurationpublic class ShiroConfigurer {
/**
* 配置shiroFilter
*
* @param securityManager
* @return
*/
//配置主类
@Bean
public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
shiroFilterFactoryBean.setSecurityManager(securityManager);
//设置不需验证url
filterFactoryBean.setLoginUrl("/login");
filterFactoryBean.setUnauthorizedUrl("/login");
Map<String, Filter> filtersMap = new LinkedHashMap();
filtersMap.put("cookie", cookieSsoFilter());
shiroFilterFactoryBean.setFilters(filtersMap);
Map<String, String> filterChainDefinitionMap = new LinkedHashMap();
//设置拦截链,定义url访问权限
filterChainDefinitionMap.put("/**", "cookie,session");
shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
return shiroFilterFactoryBean;
}
//添加自定义拦截器
@Bean(name = "cookie")
public CookieSsoFilter cookieSsoFilter() {
CookieSsoFilter cookieSsoFilter = new CookieSsoFilter();
return cookieSsoFilter;
}
//配置securityManager
@Bean
public SecurityManager securityManager() {
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
securityManager.setRealm(myShiroRealm() );
securityManager.setSessionManager(sessionManager() );
return securityManager;
}
//配置SessionManager
@Bean
public SessionManager sessionManager() {
DefaultWebSessionManager sessionManager = new DefaultWebSessionManager();
sessionManager.setGlobalSessionTimeout(86400000L);//24小时
sessionManager.setSessionDAO(sessionDAO);
return sessionManager;
}
/配置sessionDAO
@Bean
public SessionDAO sessionDAO() {
SessionDAO sessionDAO = new SessionDAO();
return sessionDAO;
}
}
三.配置集合
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- spring boot默认配置文件后缀名可以是properties或yml 运行结果如下: 两个默认配置文件的内容...