Spring MVC実行パラメータに従ってfilterエージェントを追加(起動時にfilterとlistenerを動的に追加)

4721 ワード

作業中に開発環境に関わる場合はSSOをスキップする必要があり、最初はMavenでprofilesを使用して構築時にSSOのfilterを加えるが、開発環境のweb.xmlではSSOは構成されない.使用する場合はmaven構築コマンドにパラメータを加え、テストや運営とのコミュニケーションの不便さから、別の方法を決める.
この方法はspring mvcのWebApplicationInitializerインタフェースを実装することにより,ここで実行パラメータを読み出し,このパラメータを用いてSSO filterを追加しないか(デフォルトで追加)を決定する.
実装ターゲット:実行パラメータで定義 -Dapp.env=dev、起動時にconfig/propertiesディレクトリ内のenv_をロードできるdev.propertiesファイルは、ファイル内のコンフィギュレーション項目sso.pass=trueに基づいてSSOのfilter追加をスキップします.
1、属性の定義

/**
	 *       
	 */
	private static final String SETTINGS_FILE_PREFIX = "env_";
	
	/**
	 *       key
	 */
	private static final String ENVIROMENT_KEY = "app.env";
	
	/**
	 *     SSO  key
	 */
	private static final String KEY_IS_PASS_SSO = "sso.pass"; 
	
	/**
	 *     SSO
	 */
	private static final Boolean IS_PASS_SSO;

2、運転パラメータを取得し、staticブロックで運転する
	
String env = System.getProperty(ENVIROMENT_KEY);
Properties prop = new Properties();
		if(env!=null && env.trim().length()>0){
			try {
				InputStream inputStream = ApplicationInitializer.class.getClassLoader().getResourceAsStream("config/properties/"+SETTINGS_FILE_PREFIX + env.trim()+".properties");
				prop.load(inputStream);
			} catch (IOException e) {
				logger.error("    {}    ",SETTINGS_FILE_PREFIX+env+".properties");
			}  
		}
		//SSO
		String passSSOValue = prop.getProperty(KEY_IS_PASS_SSO);
		if(StringUtils.isEmpty(passSSOValue)){
			IS_PASS_SSO = false;
		}else{
			IS_PASS_SSO = Boolean.parseBoolean(passSSOValue);
		}

3、インタフェースを実現するonStartup方法

//      
    	if(IS_PASS_SSO){
    		logger.info("     SSO");
    	}else{
    		try {
    			//     
    			servletContext.addListener("org.springframework.security.web.session.HttpSessionEventPublisher");
    			
    			//  filter
    			Dynamic addFilter = servletContext.addFilter("springSecurityFilterChain", new DelegatingFilterProxy());
    			
    			addFilter.addMappingForUrlPatterns(EnumSet.of(DispatcherType.REQUEST), false, "/*");
			} catch (Exception e) {
				logger.error("  SSO filter    ");
				throw e;
			}
    	}

終わります.
以下はすべてのコードです.
import java.io.IOException;
import java.io.InputStream;
import java.util.EnumSet;
import java.util.Properties;

import javax.servlet.DispatcherType;
import javax.servlet.FilterRegistration.Dynamic;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;

import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.WebApplicationInitializer;
import org.springframework.web.filter.DelegatingFilterProxy;

public class ApplicationInitializer implements WebApplicationInitializer {
	
	private final static Logger logger = LoggerFactory.getLogger(ApplicationInitializer.class);
	
	/**
	 *       
	 */
	private static final String SETTINGS_FILE_PREFIX = "env_";
	
	/**
	 *       key
	 */
	private static final String ENVIROMENT_KEY = "app.env";
	
	/**
	 *     SSO  key
	 */
	private static final String KEY_IS_PASS_SSO = "sso.pass"; 
	
	/**
	 *     SSO
	 */
	private static final Boolean IS_PASS_SSO;
	
	
	/**
	 *            
	 *         "env_"+    +"."
	 */
	static{
		String env = System.getProperty(ENVIROMENT_KEY);
		Properties prop = new Properties();
		if(env!=null && env.trim().length()>0){
			try {
				InputStream inputStream = ApplicationInitializer.class.getClassLoader().getResourceAsStream("config/properties/"+SETTINGS_FILE_PREFIX + env.trim()+".properties");
				prop.load(inputStream);
			} catch (IOException e) {
				logger.error("    {}    ",SETTINGS_FILE_PREFIX+env+".properties");
			}  
		}
		//SSO
		String passSSOValue = prop.getProperty(KEY_IS_PASS_SSO);
		if(StringUtils.isEmpty(passSSOValue)){
			IS_PASS_SSO = false;
		}else{
			IS_PASS_SSO = Boolean.parseBoolean(passSSOValue);
		}
	}
	
    @Override
    public void onStartup(ServletContext servletContext) throws ServletException {
    	
    	//      
    	if(IS_PASS_SSO){
    		logger.info("     SSO");
    	}else{
    		try {
    			//     
    			servletContext.addListener("org.springframework.security.web.session.HttpSessionEventPublisher");
    			
    			//  filter
    			Dynamic addFilter = servletContext.addFilter("springSecurityFilterChain", new DelegatingFilterProxy());
    			
    			addFilter.addMappingForUrlPatterns(EnumSet.of(DispatcherType.REQUEST), false, "/*");
			} catch (Exception e) {
				logger.error("  SSO filter    ");
				throw e;
			}
    	}
    }
}