spring @Value注解的任意初始赋值

本文探讨了Spring框架中@Value注解的第二种用法,即从数据库中初始化配置。示例代码展示了如何通过 Dao 层获取数据库信息,并使用MapPropertySource将这些信息添加到Spring应用上下文,以实现动态配置。通过这种方式,可以在应用程序启动时从数据库读取并设置配置参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

spring @Value注解的使用,有三种形式:1.是加载properties文件或者配置文件,从这些文件中获取;2.是任意代码中初始赋值,如固定或者数据库初始赋值;3.是动态更新赋值,用@refreshScope注解;本篇交流下第2种的任意代码初始赋值形式,下面是例子代码:

package com.test;

import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.support.GenericApplicationContext;
import org.springframework.core.env.MapPropertySource;
import org.springframework.stereotype.Component;
import com.test.dao.MemberDao;
import com.test.member.MemberEntity;

@Component
public class DbUtil implements ApplicationContextAware{
	
	@Autowired
	MemberDao memberDao;
	
	public Map<String , Object> getMailInforFromDb(){
		MemberEntity t = new MemberEntity();
		t.setId(2);
		t.setStatus("NORMAL");
		t.setGroupId(238);
		System.out.println("memberDao : " + memberDao);
		List<MemberEntity> list = memberDao.searchMember(t);
		Map<String, Object> result = new HashMap<>();
		// 固定值
		result.put("mail.host", "smtp.qq.com");
		result.put("mail.username", "java");
		result.put("mail.password", "123456");
		// 数据库获取值
		result.put("member.size", list.size());
		return result;
	}

	@Override
	public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
		// TODO Auto-generated method stub
		this.applicationContext = applicationContext;
		System.out.println("DbUtil获取容器 : " + applicationContext);
		GenericApplicationContext contextTemp =  (GenericApplicationContext) applicationContext;
		// 模拟从DB中获取配置信息
		Map<String, Object> mailInfoFromDb = this.getMailInforFromDb();
		// 将其丢在MapPropertySource中(MapPropertySource类是spring提供的一个类,是PropertySource的子类)
		MapPropertySource mailPropertySource = new MapPropertySource("mail", mailInfoFromDb);
		// 将mailPropertySource丢在Environment中的PropertySource列表的第一个中,让优先级最高
		contextTemp.getEnvironment().getPropertySources().addFirst(mailPropertySource);
	}
}
### Spring框架中`@Value`注解实现机制 在Spring框架内,`@Value` 注解用于直接赋值给字段、方法参数或构造函数参数。此功能不仅限于简单类型的字面量值,还支持SpEL(Spring Expression Language)表达式的解析[^1]。 当应用程序启动时,Spring容器会创建并初始化所有的单例Bean实例,在这个过程中对于标记有 `@Value` 的属性,Spring通过PropertySourcesPlaceholderConfigurer或者ConfigurationPropertiesBindingPostProcessor来处理这些注解。具体来说: - **字面量注入**:可以直接指定字符串或其他基本数据类型作为值传递给带有 `@Value` 注解的成员变量。 ```java @Value("Hello World") private String greeting; ``` - **环境变量/配置文件中的占位符替换**:可以利用 `${}` 语法访问外部化配置(如application.properties 或 application.yml 文件),从而允许动态设置某些特定环境下才生效的参数。 ```java @Value("${app.datasource.url}") private String dbUrl; ``` - **默认值设定**:如果希望提供一个备用选项以防所请求的数据不存在,则可以在`${key:default_value}` 中定义默认值。 ```java @Value("${server.port:8080}") private int portNumber; ``` - **复杂对象绑定**:借助 SpEL 表达式能够更灵活地操作Java集合类以及自定义POJO对象。 ```java @Value("#{T(java.lang.Math).random() * 100.0}") private double randomNumber; @Value("#{'${my.list.of.strings}'.split(',')}") private List<String> stringList; ``` 为了使上述特性正常工作,通常还需要确保项目里包含了必要的依赖项,并且正确设置了相应的配置类或XML命名空间声明[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Retank

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值