修正Shiro过滤器重复加载及加载顺序问题
This commit is contained in:
@@ -29,31 +29,30 @@ public class LogoutFilter extends org.apache.shiro.web.filter.authc.LogoutFilter
|
||||
|
||||
@Override
|
||||
protected boolean preHandle(ServletRequest request, ServletResponse response) throws Exception {
|
||||
return super.preHandle(request, response);
|
||||
// try{
|
||||
// Subject subject = getSubject(request, response);
|
||||
// String redirectUrl = getRedirectUrl(request, response, subject);
|
||||
// //try/catch added for SHIRO-298:
|
||||
// try {
|
||||
// // 记录用户退出日志
|
||||
// LogUtils.saveLog(ServletUtils.getRequest(), "系统退出");
|
||||
// // 退出登录
|
||||
// subject.logout();
|
||||
// } catch (SessionException ise) {
|
||||
// log.debug("Encountered session exception during logout. This can generally safely be ignored.", ise);
|
||||
// }
|
||||
//
|
||||
// // 如果是Ajax请求,返回Json字符串。
|
||||
// if (ServletUtils.isAjaxRequest((HttpServletRequest)request)){
|
||||
// ServletUtils.renderResult((HttpServletResponse)response, Global.TRUE, "退出成功!");
|
||||
// return false;
|
||||
// }
|
||||
//
|
||||
// issueRedirect(request, response, redirectUrl);
|
||||
// }catch(Exception e){
|
||||
// log.debug("Encountered session exception during logout. This can generally safely be ignored.", e);
|
||||
// }
|
||||
// return false;
|
||||
try{
|
||||
Subject subject = getSubject(request, response);
|
||||
String redirectUrl = getRedirectUrl(request, response, subject);
|
||||
//try/catch added for SHIRO-298:
|
||||
try {
|
||||
// 记录用户退出日志
|
||||
LogUtils.saveLog(ServletUtils.getRequest(), "系统退出");
|
||||
// 退出登录
|
||||
subject.logout();
|
||||
} catch (SessionException ise) {
|
||||
log.debug("Encountered session exception during logout. This can generally safely be ignored.", ise);
|
||||
}
|
||||
|
||||
// 如果是Ajax请求,返回Json字符串。
|
||||
if (ServletUtils.isAjaxRequest((HttpServletRequest)request)){
|
||||
ServletUtils.renderResult((HttpServletResponse)response, Global.TRUE, "退出成功!");
|
||||
return false;
|
||||
}
|
||||
|
||||
issueRedirect(request, response, redirectUrl);
|
||||
}catch(Exception e){
|
||||
log.debug("Encountered session exception during logout. This can generally safely be ignored.", e);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -61,12 +60,12 @@ public class LogoutFilter extends org.apache.shiro.web.filter.authc.LogoutFilter
|
||||
*/
|
||||
@Override
|
||||
protected String getRedirectUrl(ServletRequest request, ServletResponse response, Subject subject) {
|
||||
String url = Global.getProperty("shiro.logoutUrl");
|
||||
// 如果配置了登出之后跳转的url,并且url不能为 ${adminPath}/logout 否则会造成死循环。
|
||||
if (StringUtils.isNoneBlank(url) && !url.equals((Global.getAdminPath()+"/logout"))){
|
||||
return url;
|
||||
}
|
||||
return super.getRedirectUrl(request, response, subject);
|
||||
// String url = Global.getProperty("shiro.logoutUrl");
|
||||
// // 如果配置了登出之后跳转的url,并且url不能为 ${adminPath}/logout 否则会造成死循环。
|
||||
// if (StringUtils.isNoneBlank(url) && !url.equals((Global.getAdminPath()+"/logout"))){
|
||||
// return url;
|
||||
// }
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -17,14 +17,12 @@ public class RolesAuthorizationFilter extends org.apache.shiro.web.filter.authz.
|
||||
|
||||
@Override
|
||||
protected void redirectToLogin(ServletRequest request, ServletResponse response) throws IOException {
|
||||
super.redirectToLogin(request, response);
|
||||
// PermissionsAuthorizationFilter.redirectToDefaultPath(request, response);
|
||||
PermissionsAuthorizationFilter.redirectToDefaultPath(request, response);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean onAccessDenied(ServletRequest request, ServletResponse response) throws IOException {
|
||||
return super.onAccessDenied(request, response);
|
||||
// return PermissionsAuthorizationFilter.redirectTo403Page(request, response);
|
||||
return PermissionsAuthorizationFilter.redirectTo403Page(request, response);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
/**
|
||||
* Copyright (c) 2013-Now http://jeesite.com All rights reserved.
|
||||
*/
|
||||
package com.jeesite.config.spring;
|
||||
package com.jeesite.config.common;
|
||||
|
||||
import java.util.Map;
|
||||
|
||||
@@ -21,7 +21,9 @@ import com.jeesite.common.shiro.cas.CasOutHandler;
|
||||
import com.jeesite.common.shiro.config.FilterChainDefinitionMap;
|
||||
import com.jeesite.common.shiro.filter.CasAuthenticationFilter;
|
||||
import com.jeesite.common.shiro.filter.FormAuthenticationFilter;
|
||||
import com.jeesite.common.shiro.filter.LogoutFilter;
|
||||
import com.jeesite.common.shiro.filter.PermissionsAuthorizationFilter;
|
||||
import com.jeesite.common.shiro.filter.RolesAuthorizationFilter;
|
||||
import com.jeesite.common.shiro.filter.UserFilter;
|
||||
import com.jeesite.common.shiro.realm.AuthorizingRealm;
|
||||
import com.jeesite.common.shiro.session.SessionDAO;
|
||||
@@ -68,8 +70,7 @@ public class ShiroConfig {
|
||||
/**
|
||||
* CAS登录过滤器
|
||||
*/
|
||||
@Bean
|
||||
public CasAuthenticationFilter shiroCasFilter(AuthorizingRealm authorizingRealm) {
|
||||
private CasAuthenticationFilter shiroCasFilter(AuthorizingRealm authorizingRealm) {
|
||||
CasAuthenticationFilter bean = new CasAuthenticationFilter();
|
||||
bean.setAuthorizingRealm(authorizingRealm);
|
||||
return bean;
|
||||
@@ -78,78 +79,61 @@ public class ShiroConfig {
|
||||
/**
|
||||
* Form登录过滤器
|
||||
*/
|
||||
@Bean
|
||||
public FormAuthenticationFilter shiroAuthcFilter(AuthorizingRealm authorizingRealm) {
|
||||
private FormAuthenticationFilter shiroAuthcFilter(AuthorizingRealm authorizingRealm) {
|
||||
FormAuthenticationFilter bean = new FormAuthenticationFilter();
|
||||
bean.setAuthorizingRealm(authorizingRealm);
|
||||
return bean;
|
||||
}
|
||||
|
||||
// /**
|
||||
// * 登出过滤器
|
||||
// */
|
||||
// @Bean
|
||||
// public LogoutFilter shiroLogoutFilter() {
|
||||
// return new LogoutFilter();
|
||||
// }
|
||||
/**
|
||||
* 登出过滤器
|
||||
*/
|
||||
private LogoutFilter shiroLogoutFilter() {
|
||||
return new LogoutFilter();
|
||||
}
|
||||
|
||||
/**
|
||||
* 权限字符串过滤器
|
||||
*/
|
||||
@Bean
|
||||
public PermissionsAuthorizationFilter shiroPermsFilter() {
|
||||
private PermissionsAuthorizationFilter shiroPermsFilter() {
|
||||
return new PermissionsAuthorizationFilter();
|
||||
}
|
||||
|
||||
// /**
|
||||
// * 角色权限过滤器
|
||||
// */
|
||||
// @Bean
|
||||
// public RolesAuthorizationFilter shiroRolesFilter() {
|
||||
// return new RolesAuthorizationFilter();
|
||||
// }
|
||||
/**
|
||||
* 角色权限过滤器
|
||||
*/
|
||||
private RolesAuthorizationFilter shiroRolesFilter() {
|
||||
return new RolesAuthorizationFilter();
|
||||
}
|
||||
|
||||
/**
|
||||
* 用户权限过滤器
|
||||
*/
|
||||
@Bean
|
||||
public UserFilter shiroUserFilter() {
|
||||
private UserFilter shiroUserFilter() {
|
||||
return new UserFilter();
|
||||
}
|
||||
|
||||
/**
|
||||
* URL过滤定义
|
||||
*/
|
||||
@Bean
|
||||
public FilterChainDefinitionMap shiroFilterChainDefinitionMap() {
|
||||
FilterChainDefinitionMap bean = new FilterChainDefinitionMap();
|
||||
bean.setFilterChainDefinitions(Global.getProperty("shiro.filterChainDefinitions"));
|
||||
bean.setDefaultFilterChainDefinitions(Global.getProperty("shiro.defaultFilterChainDefinitions"));
|
||||
return bean;
|
||||
}
|
||||
|
||||
/**
|
||||
* Shiro认证过滤器
|
||||
*/
|
||||
@Bean
|
||||
public ShiroFilterFactoryBean shiroFilter(WebSecurityManager securityManager, CasAuthenticationFilter shiroCasFilter,
|
||||
FormAuthenticationFilter shiroAuthcFilter,
|
||||
// LogoutFilter shiroLogoutFilter,
|
||||
PermissionsAuthorizationFilter shiroPermsFilter,
|
||||
// RolesAuthorizationFilter shiroRolesFilter,
|
||||
UserFilter shiroUserFilter, FilterChainDefinitionMap shiroFilterChainDefinitionMap) {
|
||||
public ShiroFilterFactoryBean shiroFilter(WebSecurityManager securityManager,
|
||||
AuthorizingRealm authorizingRealm) {
|
||||
ShiroFilterFactoryBean bean = new ShiroFilterFactoryBean();
|
||||
bean.setSecurityManager(securityManager);
|
||||
bean.setLoginUrl(Global.getProperty("shiro.loginUrl"));
|
||||
bean.setSuccessUrl(Global.getProperty("shiro.successUrl"));
|
||||
Map<String, Filter> filters = bean.getFilters();
|
||||
filters.put("cas", shiroCasFilter);
|
||||
filters.put("authc", shiroAuthcFilter);
|
||||
// filters.put("logout", shiroLogoutFilter);
|
||||
filters.put("perms", shiroPermsFilter);
|
||||
// filters.put("roles", shiroRolesFilter);
|
||||
filters.put("user", shiroUserFilter);
|
||||
bean.setFilterChainDefinitionMap(shiroFilterChainDefinitionMap.getObject());
|
||||
filters.put("cas", shiroCasFilter(authorizingRealm));
|
||||
filters.put("authc", shiroAuthcFilter(authorizingRealm));
|
||||
filters.put("logout", shiroLogoutFilter());
|
||||
filters.put("perms", shiroPermsFilter());
|
||||
filters.put("roles", shiroRolesFilter());
|
||||
filters.put("user", shiroUserFilter());
|
||||
FilterChainDefinitionMap chains = new FilterChainDefinitionMap();
|
||||
chains.setFilterChainDefinitions(Global.getProperty("shiro.filterChainDefinitions"));
|
||||
chains.setDefaultFilterChainDefinitions(Global.getProperty("shiro.defaultFilterChainDefinitions"));
|
||||
bean.setFilterChainDefinitionMap(chains.getObject());
|
||||
return bean;
|
||||
}
|
||||
|
||||
@@ -167,4 +151,44 @@ public class ShiroConfig {
|
||||
return bean;
|
||||
}
|
||||
|
||||
/**
|
||||
* Shiro 生命周期处理器,实现初始化和销毁回调
|
||||
*/
|
||||
@Bean(name="lifecycleBeanPostProcessor")
|
||||
public LifecycleBeanPostProcessor lifecycleBeanPostProcessor() {
|
||||
return new LifecycleBeanPostProcessor();
|
||||
}
|
||||
|
||||
/**
|
||||
* Shiro 过滤器代理配置
|
||||
*/
|
||||
@Bean
|
||||
@DependsOn({ "lifecycleBeanPostProcessor" })
|
||||
public DefaultAdvisorAutoProxyCreator defaultAdvisorAutoProxyCreator() {
|
||||
DefaultAdvisorAutoProxyCreator bean = new DefaultAdvisorAutoProxyCreator();
|
||||
bean.setProxyTargetClass(true);
|
||||
return bean;
|
||||
}
|
||||
|
||||
/**
|
||||
* 启用Shrio授权注解拦截方式,AOP式方法级权限检查
|
||||
*/
|
||||
@Bean
|
||||
public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(WebSecurityManager securityManager) {
|
||||
AuthorizationAttributeSourceAdvisor bean = new AuthorizationAttributeSourceAdvisor();
|
||||
bean.setSecurityManager(securityManager);
|
||||
return bean;
|
||||
}
|
||||
|
||||
// /**
|
||||
// * 在方法中 注入 securityManager 进行代理控制
|
||||
// */
|
||||
// @Bean
|
||||
// public MethodInvokingFactoryBean methodInvokingFactoryBean(DefaultWebSecurityManager securityManager) {
|
||||
// MethodInvokingFactoryBean bean = new MethodInvokingFactoryBean();
|
||||
// bean.setStaticMethod("org.apache.shiro.SecurityUtils.setSecurityManager");
|
||||
// bean.setArguments(new Object[] { securityManager });
|
||||
// return bean;
|
||||
// }
|
||||
|
||||
}
|
||||
Binary file not shown.
Reference in New Issue
Block a user