springBoot整合shiro解決讀取不到@value值的問題

 1、通過@value將值注入shiroconfigure靜態屬性

    private static String dropmenu_post;
	@Value("${dropmenu.post}")
	public void setDropmenu_post(String dropmenu_post) {
		ShiroConfig.dropmenu_post = dropmenu_post;
	}

2、將LifecycleBeanPostProcessor獲取該對象的方法設爲靜態

    @Bean
	public static LifecycleBeanPostProcessor getLifecycleBeanPostProcessor() {
		return new LifecycleBeanPostProcessor();
	}

 

 3、使用

@Bean(name = "shiroFilter")
	public ShiroFilterFactoryBean getShiroFilterFactoryBean(
			@Qualifier("securityManager") SecurityManager securityManager) {
		ShiroFilterFactoryBean sfb = new ShiroFilterFactoryBean();
		sfb.setSecurityManager(securityManager);
		sfb.setLoginUrl(ShiroConfig.dropmenu_post + "/login");
		sfb.setSuccessUrl("/report/list");
		sfb.setUnauthorizedUrl("/goLogin");
		Map<String, Filter> filters = new HashMap<>();
		filters.put("per", getPermissionFilter());
		// filters.put("verCode",getVerfityCodeFilter());
		sfb.setFilters(filters);
		Map<String, String> filterMap = new LinkedHashMap<>();
		filterMap.put("/resources/**", "anon");
		filterMap.put("/fx/**", "anon");
		filterMap.put("/fx2/**", "anon");
		filterMap.put("/process/**", "anon");
		filterMap.put("/repeat/**", "anon");
		filterMap.put("/repeat2/**", "anon");
		filterMap.put("/ipad/**", "anon");
		filterMap.put("/student/**", "anon");
		filterMap.put("/excel/**", "anon");
		filterMap.put("/exam/**", "anon");
		filterMap.put("/progress/**", "anon");
		filterMap.put("/param/**", "anon");
		filterMap.put("/statics/**", "anon");
		filterMap.put("/download/**", "anon");
		filterMap.put("/knowledge/**", "anon");


		filterMap.put("/login", "anon");
		filterMap.put("/actuator/**", "anon");
		filterMap.put("/hystrix", "anon");
		filterMap.put("/hystrix.stream", "anon");
		filterMap.put("/logout", "logout");
		filterMap.put("/js/**", "anon");
		filterMap.put("/css/**", "anon");
		filterMap.put("/user/**", "per");
		filterMap.put("/**", "authc");
		sfb.setFilterChainDefinitionMap(filterMap);
		return sfb;
	}

整個類的代碼如下 

package com.whty.hxx.config;

import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;

import javax.servlet.Filter;

import org.apache.shiro.authc.credential.HashedCredentialsMatcher;
import org.apache.shiro.cache.ehcache.EhCacheManager;
import org.apache.shiro.mgt.SecurityManager;
import org.apache.shiro.spring.LifecycleBeanPostProcessor;
import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;
import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
import org.apache.shiro.web.servlet.Cookie;
import org.apache.shiro.web.servlet.ShiroHttpSession;
import org.apache.shiro.web.servlet.SimpleCookie;
import org.apache.shiro.web.session.mgt.DefaultWebSessionManager;
import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.filter.DelegatingFilterProxy;

import com.whty.hxx.common.filter.PermissionFilter;
import com.whty.hxx.common.shiro.LoginRealm;
import com.whty.hxx.common.shiro.MyWebSessionManager;
import com.whty.hxx.common.shiro.ShiroUtil;
import com.whty.hxx.common.shiro.redis.RedisSessionDAO;
import com.whty.hxx.common.shiro.redis.ShiroRedisCacheManager;

import lombok.extern.slf4j.Slf4j;

/**
 * @author yym
 * @date 2018/5/31. spring shiro 配置
 */
@Configuration
@Slf4j
public class ShiroConfig {
	private static String dropmenu_post;
	@Value("${dropmenu.post}")
	public void setDropmenu_post(String dropmenu_post) {
		ShiroConfig.dropmenu_post = dropmenu_post;
	}

	@Bean(value = "ehCacheManager")
	public EhCacheManager ehCacheManager() {
		EhCacheManager ehCacheManager = new EhCacheManager();
		ehCacheManager.setCacheManagerConfigFile("classpath:ehcache/ehcache.xml");
		return ehCacheManager;
	}

	// @Bean(name="credentialsMatcher")
	// public RetryLimitCredentialsMatcher
	// getRetryLimitCredentialsMatcher(@Qualifier("redisCacheManager")
	// ShiroSpringCacheManager redisCacheManager){
	//// RetryLimitCredentialsMatcher rm = new
	// RetryLimitCredentialsMatcher(getCacheManager(),2);
	// RetryLimitCredentialsMatcher rm = new
	// RetryLimitCredentialsMatcher(redisCacheManager);
	// rm.setHashAlgorithmName("md5");
	// rm.setHashIterations(4);
	// return rm;
	//
	// }

	// @Bean(name = "redisCacheManager")
	// public ShiroRedisCacheManager redisCacheManager() {
	// log.debug("ShiroConfiguration.redisCacheManager()");
	// return new ShiroRedisCacheManager();
	// }

	@Bean(name = "redisSessionDAO")
	public RedisSessionDAO redisSessionDAO() {
		log.debug("ShiroConfiguration.redisSessionDAO()");
		return new RedisSessionDAO();
	}

	@Bean(name = "loginRealm")
	public LoginRealm getLoginRealm(@Qualifier("redisCacheManager") ShiroRedisCacheManager redisCacheManager) {
		LoginRealm realm = new LoginRealm();
		// 密碼匹配校驗�?
		HashedCredentialsMatcher credentialsMatcher = new HashedCredentialsMatcher();
		credentialsMatcher.setHashAlgorithmName("md5");
		credentialsMatcher.setHashIterations(4);
		realm.setCredentialsMatcher(credentialsMatcher);
		realm.setCacheManager(redisCacheManager);
		// realm.setCachingEnabled(true);
		return realm;
	}

	@Bean
	public static LifecycleBeanPostProcessor getLifecycleBeanPostProcessor() {
		return new LifecycleBeanPostProcessor();
	}

	// /**
	// *
	// * enterCacheSessionDAO:(EnterpriseCacheSessionDAO shiro sessionDao層的實現�?).
	// <br/>
	// * 提供了緩存功能的會話維護,默認情況下使用MapCache實現,內部使用ConcurrentHashMap保存緩存的會話�??.<br/>
	// *
	// * @author verywell
	// * @return
	// * @since JDK 1.8
	// */
	// @Bean(name="redisCacheSessionDAO")
	// public RedisSessionDao
	// getEnterCacheSessionDAO(@Qualifier("redisCacheManager")
	// ShiroSpringCacheManager redisCacheManager) {
	// RedisSessionDao enterCacheSessionDAO = new RedisSessionDao();
	// //添加緩存管理�?
	// enterCacheSessionDAO.setCacheManager(redisCacheManager);
	//// 添加ehcache活躍緩存名稱(必須和ehcache緩存名稱�?致)
	//// enterCacheSessionDAO.setActiveSessionsCacheName("shiro-activeSessionCache");
	// return enterCacheSessionDAO;
	// }

	// @Bean(name="sessionValidationScheduler")
	// public MyQuartzSessionValidationScheduler
	// getQuartzSessionValidationScheduler(@Qualifier("redisSessionDAO")RedisSessionDAO
	// sessionDAO
	// ,@Qualifier("redisCacheManager") ShiroRedisCacheManager redisCacheManager) {
	// MyQuartzSessionValidationScheduler sessionValidationScheduler = new
	// MyQuartzSessionValidationScheduler();
	// sessionValidationScheduler.setSessionValidationInterval(10000);
	// DefaultWebSessionManager sessionManager=new DefaultWebSessionManager();
	// sessionManager.setCacheManager(redisCacheManager);
	// sessionManager.setSessionDAO(sessionDAO);
	// sessionValidationScheduler.setSessionManager(sessionManager);
	// return sessionValidationScheduler;
	// }

	@Bean(name = "sessionManager")
	public DefaultWebSessionManager getSessionManager(@Qualifier("redisSessionDAO") RedisSessionDAO sessionDAO,
			@Qualifier("redisCacheManager") ShiroRedisCacheManager cacheManager) {
		MyWebSessionManager sessionManager = new MyWebSessionManager();
		sessionManager.setSessionIdUrlRewritingEnabled(false);// sessionId不顯示在url�?
		sessionManager.setCacheManager(cacheManager);
		sessionManager.setSessionDAO(sessionDAO);
		// sessionManager.setGlobalSessionTimeout(2000);
		// sessionManager.setSessionValidationScheduler(sessionValidationScheduler);
		// sessionManager.setSessionValidationInterval(3000);
		// 創建會話Cookie
		Cookie cookie = new SimpleCookie(ShiroHttpSession.DEFAULT_SESSION_ID_NAME);
		cookie.setName(ShiroUtil.name_serssionId);
		cookie.setHttpOnly(true);
		sessionManager.setSessionIdCookie(cookie);
		return sessionManager;
	}

	@Bean(name = "securityManager")
	public SecurityManager getSecurityManager(@Qualifier("loginRealm") LoginRealm loginRealm,
			@Qualifier("sessionManager") DefaultWebSessionManager sessionManager,
			@Qualifier("redisCacheManager") ShiroRedisCacheManager cacheManager) {
		DefaultWebSecurityManager dwm = new DefaultWebSecurityManager();
		dwm.setRealm(loginRealm);
		// dwm.setCacheManager(cacheManager);
		dwm.setSessionManager(sessionManager);
		return dwm;
	}

	@Bean
	public PermissionFilter getPermissionFilter() {
		PermissionFilter pf = new PermissionFilter();
		return pf;
	}

	// @Bean
	// public VerfityCodeFilter getVerfityCodeFilter(){
	// VerfityCodeFilter vf= new VerfityCodeFilter();
	// vf.setFailureKeyAttribute("shiroLoginFailure");
	// vf.setJcaptchaParam("code");
	// vf.setVerfitiCode(true);
	// return vf;
	// }

	@Bean(name = "shiroFilter")
	public ShiroFilterFactoryBean getShiroFilterFactoryBean(
			@Qualifier("securityManager") SecurityManager securityManager) {
		ShiroFilterFactoryBean sfb = new ShiroFilterFactoryBean();
		sfb.setSecurityManager(securityManager);
		sfb.setLoginUrl(ShiroConfig.dropmenu_post + "/login");
		sfb.setSuccessUrl("/report/list");
		sfb.setUnauthorizedUrl("/goLogin");
		Map<String, Filter> filters = new HashMap<>();
		filters.put("per", getPermissionFilter());
		// filters.put("verCode",getVerfityCodeFilter());
		sfb.setFilters(filters);
		Map<String, String> filterMap = new LinkedHashMap<>();
		filterMap.put("/resources/**", "anon");
		filterMap.put("/fx/**", "anon");
		filterMap.put("/fx2/**", "anon");
		filterMap.put("/process/**", "anon");
		filterMap.put("/repeat/**", "anon");
		filterMap.put("/repeat2/**", "anon");
		filterMap.put("/ipad/**", "anon");
		filterMap.put("/student/**", "anon");
		filterMap.put("/excel/**", "anon");
		filterMap.put("/exam/**", "anon");
		filterMap.put("/progress/**", "anon");
		filterMap.put("/param/**", "anon");
		filterMap.put("/statics/**", "anon");
		filterMap.put("/download/**", "anon");
		filterMap.put("/knowledge/**", "anon");

		// //===== 測試
		// filterMap.put("/test/**","anon");
		// filterMap.put("/report/**","anon");
		// filterMap.put("/upload/**","anon");
		// filterMap.put("/city/**","anon");
		// filterMap.put("/county/**","anon");
		// filterMap.put("/unitSchool/**","anon");
		// filterMap.put("/regionSchool/**","anon");
		// filterMap.put("/school/**","anon");
		// filterMap.put("/clazz/**","anon");
		// filterMap.put("/clazzEvaluation/**","anon");
		// filterMap.put("/schoolEvaluation/**","anon");
		// filterMap.put("/canvas/**","anon");
		// //===== end

		filterMap.put("/login", "anon");
		filterMap.put("/actuator/**", "anon");
		filterMap.put("/hystrix", "anon");
		filterMap.put("/hystrix.stream", "anon");
		filterMap.put("/logout", "logout");
		filterMap.put("/js/**", "anon");
		filterMap.put("/css/**", "anon");
		filterMap.put("/user/**", "per");
		filterMap.put("/**", "authc");
		sfb.setFilterChainDefinitionMap(filterMap);
		return sfb;
	}

	@Bean
	public DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator() {
		DefaultAdvisorAutoProxyCreator advisorAutoProxyCreator = new DefaultAdvisorAutoProxyCreator();
		advisorAutoProxyCreator.setProxyTargetClass(true);
		return advisorAutoProxyCreator;
	}

	@Bean
	public AuthorizationAttributeSourceAdvisor getAuthorizationAttributeSourceAdvisor(
			@Qualifier("securityManager") SecurityManager securityManager) {
		AuthorizationAttributeSourceAdvisor as = new AuthorizationAttributeSourceAdvisor();
		as.setSecurityManager(securityManager);
		return as;
	}

	@Bean
	public FilterRegistrationBean delegatingFilterProxy() {
		FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();
		DelegatingFilterProxy proxy = new DelegatingFilterProxy();
		proxy.setTargetFilterLifecycle(true);
		proxy.setTargetBeanName("shiroFilter");

		filterRegistrationBean.setFilter(proxy);
		return filterRegistrationBean;
	}

}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章