一、@Value注解的作用。
为了减小耦合度,通常,将一些固定的常量放在配置文件***.properties中。
properties内容定义形式:名称=值
- SAY_COUNT=10
- TITLE_COUNT=10
- MESSAGE_COUNT=10
- BACK_COUNT=10
当需要这些常量的时候,通过加载properties文件,在需要的位置使用这些常量,当需要修改这些常量值的时候,只要在配置文件中修改就可以了。
在没有使用spring之前,想使用配置文件当中的数据必须得自己手工写代码加载配置文件。但是在使用spring的时候,这种操作可以通过在spring中添加一个配置来完成。
- <context:property-placeholder location="classpath:resource/resource.properties"/>
- @Value("${INDEX_TITLE}")
- private Integer INDEX_TITLE;
二、获取不到值的情况。
1)当SpringMVC与Spring整合使用的时候,在Controller中无法获取@Value对应的值。(刚开始我就是这种情况,,,,)
产生原因: 只在applicationContext中添加了扫描,没有在SpringMVC对应的配置文件中扫描。
applicationContext加载的是父容器,,父容器在项目启动的时候就被加载了。SpringMVC对应的配置文件加载的是子容器,子容器可以访问父容器的对象,但是不能访问加载的配置文件。所以,如果想在SpringMVC中使用加载的配置文件,需要在SpringMVC对应的配置文件中添加相应的配置即可。
2)在service或者dao层无法获取@Value的数值。
可能情况:有多个applicationContext.xml文件,里面有多个context:property-placeholder,在web容器启动的时候同时加载了这些配置文件,这时候只会有一个配置文件中的context:property-placeholder会被加载,其他的不会被加载。
那么,当需要加载多个properties的时候,如何解决?可以用下面的方法- <context:property-placeholder location="classpath:resource/*.properties"/>