工具类之SpringBoot手动获取bean

一、工具类

/**
 * 实现ApplicationContextAware接口,并加入Component注解,让spring扫描到该bean
 * 该类用于在普通Java类中注入bean,普通Java类中用@Autowired是无法注入bean的
 */
@Component
public class SpringBeanUtil implements ApplicationContextAware {
 
    private static ApplicationContext applicationContext;
 
    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        if(SpringBeanUtil.applicationContext == null) {
            SpringBeanUtil.applicationContext = applicationContext;
        }
    }
 
    /**
     * 获取applicationContext
     */
    public static ApplicationContext getApplicationContext() {
        return applicationContext;
    }
 
    /**
     *通过name获取 Bean.
     * @param name
     * @return
     */
    public static Object getBean(String name){
        return getApplicationContext().getBean(name);
    }
 
    /**
     * 通过class获取Bean.
     * @param clazz
     * @param <T>
     * @return
     */
    public static <T> T getBean(Class<T> clazz){
        return getApplicationContext().getBean(clazz);
    }
 
    /**
     * 通过name,以及Clazz返回指定的Bean
     * @param name
     * @param clazz
     * @param <T>
     * @return
     */
    public static <T> T getBean(String name,Class<T> clazz){
        return getApplicationContext().getBean(name, clazz);
    }
}

二、应用

在普通类中无法通过@Autowired自动导入,可以通过该工具类进行导入

private static StringRedisTemplate stringRedisTemplate = SpringBeanUtil.getBean(StringRedisTemplate.class);

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Spring Boot中的DataSource工具类是用于配置和管理数据库连接的类。它可以帮助我们简化数据库连接的配置,提供连接池功能,以及管理数据库事务。 在Spring Boot中,我们通常使用Spring的JdbcTemplate来操作数据库。JdbcTemplate需要一个DataSource对象作为参数,用于获取数据库连接。因此,我们需要配置一个DataSource对象,并将其注入到JdbcTemplate中。 在配置DataSource时,我们可以使用Spring Boot提供的自动配置功能,也可以通过编写自定义配置类来手动配置。自动配置功能会根据我们的依赖和配置文件中的属性自动创建和配置DataSource对象。 下面是一个使用自动配置功能的示例: ```java @SpringBootApplication public class MyApp { public static void main(String[] args) { SpringApplication.run(MyApp.class, args); } @Autowired private JdbcTemplate jdbcTemplate; // 使用JdbcTemplate进行数据库操作 public void doSomething() { String sql = "SELECT * FROM users"; List<User> users = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class)); // ... } } ``` 在上面的示例中,我们通过@Autowired注解将JdbcTemplate对象注入到了MyApp类中。Spring Boot会自动根据配置文件中的属性创建DataSource对象,并将其注入到JdbcTemplate中。 除了自动配置外,我们还可以通过编写自定义配置类来手动配置DataSource。例如: ```java @Configuration public class DataSourceConfig { @Value("${spring.datasource.url}") private String url; @Value("${spring.datasource.username}") private String username; @Value("${spring.datasource.password}") private String password; @Value("${spring.datasource.driver-class-name}") private String driverClassName; @Bean public DataSource dataSource() { DriverManagerDataSource dataSource = new DriverManagerDataSource(); dataSource.setUrl(url); dataSource.setUsername(username); dataSource.setPassword(password); dataSource.setDriverClassName(driverClassName); return dataSource; } } ``` 在上面的示例中,我们通过@Configuration注解将该类标记为配置类,并使用@Bean注解将dataSource方法声明为一个Bean。方法中的代码会创建一个DriverManagerDataSource对象,并设置相关属性。 这只是DataSource工具类的简单示例,实际应用中可能还需要配置连接池、事务管理等功能。不同的数据库连接池和事务管理器可能有不同的配置方式,请根据具体情况进行配置。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值