java - Spring:使用 @Value 注释时,Bean 无法从外部属性文件读取值

标签 java spring annotations spring-annotations

XML 配置

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:util="http://www.springframework.org/schema/util"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">

    <util:properties id="mongoProperties" location="file:///storage/local.properties" />

    <bean id="mongoService" class="com.business.persist.MongoService"></bean>
</beans>

MongoService 看起来像

@Service
public class MongoService {

    @Value("#{mongoProperties[host]}")
    private String host;

    @Value("#{mongoProperties[port]}")
    private int port;

    @Value("#{mongoProperties[database]}")
    private String database;

    private Mongo mongo;

    private static final Logger LOGGER = LoggerFactory.getLogger(MongoService.class);

    public MongoService() throws UnknownHostException {
        LOGGER.info("host=" + host + ", port=" + port + ", database=" + database);
        mongo = new Mongo(host, port);
    }

    public void putDocument(@Nonnull final DBObject document) {
        LOGGER.info("inserting document - " + document.toString());
        mongo.getDB(database).getCollection(getCollectionName(document)).insert(document, WriteConcern.SAFE);
    }

我将 MongoServiceTest 写为

public class MongoServiceTest {

    @Autowired
    private MongoService mongoService;

    public MongoServiceTest() throws UnknownHostException {
        mongoRule = new MongoRule();
    }

    @Test
    public void testMongoService() {
        final DBObject document = DBContract.getUniqueQuery("001");
        document.put(DBContract.RVARIABLES, "values");
        document.put(DBContract.PVARIABLES, "values");

        mongoService.putDocument(document);
    }

我认为测试失败为

12:37:25.224 [main] INFO  c.s.business.persist.MongoService - host=null, port=0, database=null
java.lang.NullPointerException
    at com.business.persist.MongoServiceTest.testMongoService(MongoServiceTest.java:40)

这意味着 bean 无法从 local.properties 读取值

本地属性

### === MongoDB interaction === ###
host="127.0.0.1"
port=27017
database=contract

我该如何解决这个问题?

更新 即使在为字段创建 setter/getter 后,它似乎也不会读取值。我现在真是一无所知。

更新01

添加init()方法并将其添加到bean后,它仍然不起作用。我什至没有看到日志消息
XML

<bean id="mongoService" class="com.business.persist.MongoService" init-method="init"></bean>

MongoService

@Service
public class MongoService {

    @Value("#{mongoProperties['host']}")
    private String host;

    @Value("#{mongoProperties['port']}")
    private int port;

    @Value("#{mongoProperties['database']}")
    private String database;

    private Mongo mongo;

    private static final Logger LOGGER = LoggerFactory.getLogger(MongoService.class);

    public MongoService() {}

    public void init() throws UnknownHostException {
        LOGGER.info("host=" + host + ", port=" + port + ", database=" + database);
        mongo = new Mongo(host, port);
    }

    public void putDocument(@Nonnull final DBObject document) {
        LOGGER.info("inserting document - " + document.toString());
        mongo.getDB(database).getCollection(getCollectionName(document)).insert(document, WriteConcern.SAFE);
    }

我该如何调试这个问题?

非常感谢!

最佳答案

我在这里看到一个问题,您正在 MongoService 构造函数中实例化 Mongo 类,但是此时您的属性尚未基于 local.properties< 注入(inject) 文件中的主机、端口和数据库的值将为空。

相反,您可以做的是不在 Service 构造函数中实例化 Mongo 类,让属性按照您的方式注入(inject)到 MongoService 中,然后将其创建为 init 方法的一部分,该方法在您的属性被调用后调用设置:

在 MongoService 中:

public void init(){
    mongo = new Mongo(host, port);
}

在你的bean配置中:

<bean id="mongoService" class="com.business.persist.MongoService" init-method="init"></bean>

关于java - Spring:使用 @Value 注释时,Bean 无法从外部属性文件读取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11268049/

相关文章:

java - Spring 集成 - Jboss 的多个实例监听同一邮件服务器是否会导致重复?

java - RxJava 2 : emit collected list of items after a certain period of time

java - JBoss EAP6 与外部 HornetQ 实现的连接不起作用,但在 JBoss 7.1.1 中却可以

php - Symfony2 : Where/how I can trigger my own annotation-reader?

java - java.lang.annotation.Target 的 @Target({}) 的任何示例用法?

javascript - 如何使用商店插件 annotatorjs 加载注释?

java - 在我的主要 Activity 中将 sqlite 数据库中的值显示到 ListView 。安卓

java - ConcurrentModificationException 的魔数(Magic Number)

java - 使用 spring boot 和 kotlin 进行单元/休息测试的艰苦战斗

java - 由 : java. sql.SQLSyntaxErrorException 引起:ORA-01722:JPA HIBERNATE HQL 中的数字无效