Tomcat 未读取 Spring-Boot 应用程序属性

2022-09-01 15:51:27

我对spring/java相当陌生,并且一直在为我的工作中的一个项目检查spring-boot。我一直在遵循指南,终于有一个(半)工作的Web应用程序MVC + JPA用于数据访问。当我通过Jar方法部署应用程序时,一切都有效:

java -jar build/libs/client.jar

但是,我们的应用程序最终将部署到Tomcat(v7.0.40),因此我需要从该项目创建一个war文件。我遵循了 spring.io 网站上将罐子转换为战争指南,并遇到了一个问题。它似乎没有加载应用程序属性文件。以下是重要的代码片段:

src/main/java/hello/GreetingController:

@Controller
@Configuration
public class GreetingController {
    @Value("${app.username}")
    private String username;

    @RequestMapping("/greeting")
    public String greeting(@RequestParam(value="name", required=false, defaultValue="World") String name, Model model) {
        model.addAttribute("name", name);
        model.addAttribute("username", username);
        return "greeting";
    }
} 

src/main/java/hello/Application.java

@ComponentScan
@EnableAutoConfiguration
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }
}

src/main/java/hello/HelloWebXml.java

public class HelloWebXml extends SpringBootServletInitializer {

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
        return application.sources(Application.class);
    }
}

src/main/resources/application.properties

app.username=foo

为了完整起见,这里是 build.gradle:

buildscript {
    repositories {
        maven { url "http://repo.spring.io/libs-snapshot" }
        mavenLocal()
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:0.5.0.M6")
    }
}

apply plugin: 'java'
apply plugin: 'eclipse-wtp'
apply plugin: 'idea'
apply plugin: 'spring-boot'
apply plugin: 'war'

war {
    baseName = 'client'
    version =  '0.1.0'
}

repositories {
    mavenCentral()
    maven { url "http://repo.spring.io/libs-snapshot" }
}

dependencies {
    compile("org.springframework.boot:spring-boot-starter-web:0.5.0.M6")
    compile("org.thymeleaf:thymeleaf-spring3:2.0.16")
    testCompile("junit:junit:4.11")
}

task wrapper(type: Wrapper) {
    gradleVersion = '1.8'
}

我构建应用程序:

gradle clean build

在tomcat中放下战争,然后尾随日志并查看以下内容:

SEVERE: ContainerBase.addChild: start:
org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina]
.StandardHost[localhost].StandardContext[/client]]
...
...
...
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating the bean
with name 'greetingController': Injection of autowired dependencies failed; nested exception
is java.lang.IllegalArgumentException: Could not resolve placeholder 'app.username' in string
value "${app.username}"
...
...
...

正如我所说,当我通过jar运行它时,它可以工作,但是当我将它部署到Tomcat时,它不起作用。我也看了看里面,我看到了文件。所以我认为它应该在类路径上。我的问题是,为什么雄猫不加载它?我尝试到处搜索,似乎没有其他人遇到这个问题,所以我不确定它是否只是我错误配置的东西,或者是什么。$TOMCAT_HOME/webapps/client/WEB-INF/classesapplication.properties

提前致谢。


答案 1

遵循这个家伙的建议:http://blog.codeleak.pl/2013/11/how-to-propertysource-annotations-in.html

尝试:

@PropertySources(value = {@PropertySource("classpath:application.properties")})

然后为胜利而轰动一时。


答案 2

问题是您尝试在类中使用注释。来自@PropertySource的JavaDoc:@Value@Configuration

为了解析<bean>定义中的 ${...} 占位符,或者使用 PropertySource 中的属性@Value注释,必须注册一个 PropertySourcesPlaceholderConfigurer。在 XML 中使用<context:property-placeholder>时,这会自动发生,但在使用@Configuration类时必须使用静态@Bean方法显式注册。

例如,将以下行添加到类中:@Configuration

@Bean
public static PropertySourcesPlaceholderConfigurer propertyPlaceholderConfigurer() {
    return new PropertySourcesPlaceholderConfigurer();
}

但是,在您的示例中,更合适的方法是将批注从类(不包含任何配置)移动到类。由于该类不包含任何注释,因此它应该在没有建议添加静态bean的情况下工作。@ConfigurationGreetingControllerApplicationApplication@ValuePropertySourcesPlaceholderConfigurer


推荐