使用Spring基于用户输入

时间:2017-06-15 12:55:53

标签: java spring

我遇到过Spring问题,我需要你的帮助。我试图从阅读以下内容从属性文件更改为直接自动装入类:

#Supported Versions of Tools
language.python=2.7.1
language.java=1.8
language.scala=2.10

问题是我希望能够轻松添加其他语言。当它是属性文件时,我使用的是命令String supportedVersion = props.getProperty("language." + language.toLowerCase());。在线进行一些研究后,我通过this StackOverflow question的解决方案可以很好地工作,所以我将代码修改为:

 @Component("PropertiesAnalyzer")
public class PropertiesAnalyzer implements FileAnalyzer, java.io.Serializable {

           @Autowired
       private Environment environment;
       …
       public boolean validLanguageVersion(String version, String language) {
              if (version == null) {
                     // assume default
                     return true;
              }
              // Get supported version from file
              String supportedVersion = getLanguageVersion(language);

              // Compare the provided versions
              if (compareVersions(version, supportedVersion) != -1)
                     return true;
              return false;
       }

       private String getLanguageVersion(String language){
              return environment.resolvePlaceholders("${language." + language.toLowerCase() + "}");
       }

但是当我运行单元测试时,它返回$ {language.java}的值而不是1.8:

public class PropertiesAnalyzerTest {

       private static PropertiesAnalyzer analyzer;

       @BeforeClass
       public static void setUpBeforeClass() throws Exception {
              ApplicationContext applicationContext = new AnnotationConfigApplicationContext("com.my.package");
              analyzer = (PropertiesAnalyzer) applicationContext.getBean("PropertiesAnalyzer");
       }
       @Test
       public void testValidLanguage_java() {
              assertTrue(analyzer.validLanguageVersion("1.9", "java"));
       }
}

然后我尝试将我的代码更新为:

private String getLanguageVersion(String language){
          String property = "language." + language.toLowerCase();
          return environment.getProperty(property);
   }

environment.getProperty(property)返回null。我知道它可以读取属性文件,因为如果我更新代码以使用@Value,则打印出正确的信息。

       @Autowired
       private ApplicationContext applicationContext;
       private Environment environment;

       @Value("${language.java}")
       private String languageJava;

       /**
       * Empty constructor
       */
       public PropertiesAnalyzer() {
              System.out.println("Test");
       }

       @PostConstruct
       public void init(){
              System.out.println("TestInit");
              environment = applicationContext.getEnvironment();
              System.out.println("LanguageJava = " + languageJava);
              System.out.println("Environment: " + environment.getProperty("language.java"));   
              System.out.println("EnvironmnetResolver: " + environment.resolvePlaceholders("${language.java}"));
       }

打印出来:

Test
TestInit
LanguageJava = 1.8
Environment: null
EnvironmnetResolver: ${language.java}

我做错了什么?为什么我不能从环境中读取文件中的属性?

注意 - 我声明PropertyPlaceholderConfigurer指定属性文件在不同类中的位置。

1 个答案:

答案 0 :(得分:0)

在测试执行过程中,我遇到了类似的问题。 为了解决这个问题,我已经用下面的方法在环境中注册了所需的属性源:

@Configuration
public class SomeConfiguration {

   @Bean
   public PropertyPlaceholderConfigurer propertyPlaceholderConfigurer(Environment e) {
      ((StandardServletEnvironment)e).getPropertySources().addLast(new ResourcePropertySource("<path-to-properties-file>"));
   }
}

之后,您可以按照代码中提到的方式访问所需的属性。

希望这会有所帮助。