返回顶部
首页 > 资讯 > 精选 >Spring单元测试控制Bean注入的方法是什么
  • 692
分享到

Spring单元测试控制Bean注入的方法是什么

2023-07-05 23:07:58 692人浏览 八月长安
摘要

本篇内容介绍了“spring单元测试控制Bean注入的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!通过xml文件进行注入在配置文

本篇内容介绍了“spring单元测试控制Bean注入的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    通过xml文件进行注入

    在配置文件中指定要注入的bean

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="Http://www.springframework.org/schema/beans"       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">    <bean id="dog" class="com.ttpfx.entity.Dog">        <property name="name" value="旺财"/>        <property name="age" value="18"/>    </bean></beans>

    然后spring加载这个xml文件就可以实现注入

    public class SpringTest1 {    public static void main(String[] args) {        ApplicationContext ioc = new ClassPathXmlApplicationContext("applicationContext.xml");        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);    }}

    输出为

    dog

    通过xml加注解方式进行注入

    编写xml配置文件,里面指定要扫描的包

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"       xmlns:context="http://www.springframework.org/schema/context"       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">    <!-- 扫描 com.ttpfx.entity.t2 包下的所有bean-->    <context:component-scan base-package="com.ttpfx.entity.t2"/></beans>

    然后在要注入的bean上加入Component注解即可(如果里面方法上面有@Bean,那么也会进行处理)

    @Componentpublic class Cat {}
    public class SpringTest2 {    public static void main(String[] args) {        ApplicationContext ioc = new ClassPathXmlApplicationContext("applicationContext2.xml");        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);    }}

    输出为

    cat
    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory

    通过注解进行注入

    可以不使用xml文件,通过@ComponentScan注解来完成定义扫描路径的功能

    @ComponentScan(basePackages = "com.ttpfx.entity.t3")public class SprinGConfig3 {}
    public class SpringTest3 {    public static void main(String[] args) {        ApplicationContext ioc = new AnnotationConfigApplicationContext(SpringConfig3.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);    }}

    使用@ComponentScan也会将自身加入到容器中。我们可以在方法上加入@Bean来进行注入,具体如下

    @Component和@Configuration的区别

    二者用法基本一样,只不过@Configuration可以控制注入的Bean是不是一个代理对象,如果是代理对象,那么调用@Bean方法返回的都是同一个对象,否则就不是同一个对象。

    在默认情况下,@Configuration注入的对象是一个代理对象

    默认情况,proxyBeanMethods = true

    @Configuration(proxyBeanMethods = true)public class Cat {    @Bean    public Cat bigCat() {        return new Cat();    }}

    得到这个对象,然后调用bigCat这个方法

    public class SpringTest2 {    public static void main(String[] args) {        ApplicationContext ioc = new ClassPathXmlApplicationContext("applicationContext2.xml");        Cat cat = ioc.getBean("cat", Cat.class);        System.out.println(cat);        Cat bigCat1 = cat.bigCat();        Cat bigCat2 = cat.bigCat();        System.out.println("---------------------");        System.out.println(bigCat1);        System.out.println(bigCat2);        System.out.println(bigCat1 == bigCat2);    }}

    这时返回Cat已经是一个代理对象了,bigCat返回的都是同一个对象,就是单例模式的。

    com.ttpfx.entity.t2.Cat$$EnhancerBySpringCGLIB$$bc3ad26b@4c1d9d4b
    ---------------------
    com.ttpfx.entity.t2.Cat@7b227d8d
    com.ttpfx.entity.t2.Cat@7b227d8d
    true

    如果将proxyBeanMethods 改成false,情况如下

    @Configuration(proxyBeanMethods = false)public class Cat {    @Bean    public Cat bigCat() {        return new Cat();    }}

    其他代码不变,可以发现没有进行代理。

    com.ttpfx.entity.t2.Cat@62fdb4a6
    ---------------------
    com.ttpfx.entity.t2.Cat@11e21d0e
    com.ttpfx.entity.t2.Cat@1dd02175
    false

    如果使用@Component,那么就相当于@Configuration的proxyBeanMethods 设置为false

    使用FactoryBean

    我们可以让一个类实现FactoryBean,这个接口有一个getObject方法,如果一个使用@Bean标记的方法返回FactoryBean,那么最终返回的是FactoryBean的getObject方法返回的值

    public class PeopleFactory implements FactoryBean<People> {    @Override    public People getObject() throws Exception {        return new People();    }    @Override    public Class<?> getObjectType() {        return People.class;    }    @Override    public boolean isSingleton() {        return FactoryBean.super.isSingleton();    }}
    @Componentpublic class People {    @Bean    public PeopleFactory peopleFactory(){        return new PeopleFactory();    }}

    此时获取peopleFactory,它的类型如下,是一个People类型

    com.ttpfx.entity.t3.People@587c290d

    通过@Import导入

    可以使用@Import进行导入

    @Import({User.class})public class SpringConfig4 {}
    public class SpringTest4 {    public static void main(String[] args) {        ApplicationContext ioc = new AnnotationConfigApplicationContext(SpringConfig4.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);    }}

    输出如下,可以发现使用@Import标注的类也会被注入。使用@Import导入的类,名称为全类名,如果重复导入,那么后面覆盖前面。要指定名称,那么就在对应的bean上面使用@Component即可

    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory
    springConfig4
    com.ttpfx.entity.t4.User

    手动注入(reGISterBean)

    可以直接通过GenericApplicationContext这个类的registerBean方法进行注入

    public class SpringTest5 {    public static void main(String[] args) {        AnnotationConfigApplicationContext ioc = new AnnotationConfigApplicationContext(SpringConfig5.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);        System.out.println("-----------------------");        ioc.registerBean("monster01", Monster.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);    }}

    输出如下

    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory
    springConfig5
    -----------------------
    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory
    springConfig5
    monster01

    通过ImportSelector进行注入

    定义一个类实现ImportSelector

    public class MyImportSelector implements ImportSelector {    @Override    public String[] selectImports(AnnotationMetadata importingClaSSMetadata) {        return new String[]{"com.ttpfx.entity.t6.Pig"};    }}
    @Import({MyImportSelector.class})public class SpringConfig6 {}
    public class SpringTest6 {    public static void main(String[] args) {        ApplicationContext ioc = new AnnotationConfigApplicationContext(SpringConfig6.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);    }}

    输出如下,可以发现selectImports返回的String字符串中的内容会进行注入

    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory
    springConfig6
    com.ttpfx.entity.t6.Pig

    通过ImportBeanDefinitionRegistrar进行注入

    通过ImportBeanDefinitionRegistrar可以进行注入,只需要在registerBeanDefinitions方法中使用BeanDefinitionRegistry的registerBeanDefinition方法即可

    public class MyImportBeanDefinitionRegistrar implements ImportBeanDefinitionRegistrar {    @Override    public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry, BeanNameGenerator importBeanNameGenerator) {        ImportBeanDefinitionRegistrar.super.registerBeanDefinitions(importingClassMetadata, registry, importBeanNameGenerator);    }    @Override    public void registerBeanDefinitions(AnnotationMetadata importingClassMetadata, BeanDefinitionRegistry registry) {        BeanDefinition beanDefinition = BeanDefinitionBuilder.rootBeanDefinition(Manager.class).getBeanDefinition();        registry.registerBeanDefinition("manager", beanDefinition);        ImportBeanDefinitionRegistrar.super.registerBeanDefinitions(importingClassMetadata, registry);    }}
    public class SpringTest7 {    public static void main(String[] args) {        ApplicationContext ioc = new AnnotationConfigApplicationContext(SpringConfig7.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);        Manager bean = ioc.getBean(Manager.class);        System.out.println(bean);    }}

    代码输出如下

    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory
    springConfig7
    manager
    com.ttpfx.entity.t7.Manager@1d8d30f7

    通过BeanDefinitionRegistryPostProcessor进行注入

    实现这个接口,通过方法上面的参数可以进行注入

    public class MyBeanDefinitionRegistryPostProcessor implements BeanDefinitionRegistryPostProcessor {    @Override    public void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry registry) throws BeansException {        BeanDefinition beanDefinition = BeanDefinitionBuilder.rootBeanDefinition(Employee.class).getBeanDefinition();        registry.registerBeanDefinition("employee", beanDefinition);    }    @Override    public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {    }}
    @Import({MyBeanDefinitionRegistryPostProcessor.class})public class SpringConfig8 {}
    public class SpringTest8 {    public static void main(String[] args) {        ApplicationContext ioc = new AnnotationConfigApplicationContext(SpringConfig8.class);        Arrays.stream(ioc.getBeanDefinitionNames()).forEach(System.out::println);        System.out.println("-----------------");        Employee bean = ioc.getBean(Employee.class);        System.out.println(bean);    }}

    输出如下,可以发现实现BeanDefinitionRegistryPostProcessor的这个类也被注入了

    org.springframework.context.annotation.internalConfigurationAnnotationProcessor
    org.springframework.context.annotation.internalAutowiredAnnotationProcessor
    org.springframework.context.annotation.internalCommonAnnotationProcessor
    org.springframework.context.event.internalEventListenerProcessor
    org.springframework.context.event.internalEventListenerFactory
    springConfig8
    com.ttpfx.entity.t8.MyBeanDefinitionRegistryPostProcessor
    employee
    -----------------
    com.ttpfx.entity.t8.Employee@58c1670b

    “Spring单元测试控制Bean注入的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    --结束END--

    本文标题: Spring单元测试控制Bean注入的方法是什么

    本文链接: https://lsjlt.com/news/356440.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • Spring单元测试控制Bean注入的方法是什么
      本篇内容介绍了“Spring单元测试控制Bean注入的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!通过xml文件进行注入在配置文...
      99+
      2023-07-05
    • Spring单元测试控制Bean注入的方式
      目录通过xml文件进行注入通过xml加注解方式进行注入通过注解进行注入@Component和@Configuration的区别使用FactoryBean通过@Import导入手动注入...
      99+
      2023-05-15
      Spring注入bean Spring注入bean的方法
    • Spring怎么控制Bean注入的顺序
      今天小编给大家分享一下Spring怎么控制Bean注入的顺序的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。简介说明首先需要说...
      99+
      2023-07-02
    • Spring中bean集合注入的方法是什么
      这篇文章主要讲解了“Spring中bean集合注入的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Spring中bean集合注入的方法是什么”吧!Spring作为项目中不可缺少的底...
      99+
      2023-07-02
    • Mock注入的Dubbo bean方法是什么
      这篇文章主要介绍“Mock注入的Dubbo bean方法是什么”,在日常操作中,相信很多人在Mock注入的Dubbo bean方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mock注入的Dubbo ...
      99+
      2023-06-19
    • spring中向一个单例bean中注入非单例bean的方法详解
      目录前言错误实例演示 实现ApplicationContextAware接口 lookup method lookup method签名 总结 前言 看到这个题目相信很多小伙伴都是懵...
      99+
      2024-04-02
    • 微信小程序单元测试的方法是什么
      这篇文章主要讲解了“微信小程序单元测试的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序单元测试的方法是什么”吧!程序设计,实现之后的下一个环节就是单元测试了。对于位置闹铃...
      99+
      2023-06-19
    • JavaScript单元测试的作用是什么
      这篇文章主要介绍“JavaScript单元测试的作用是什么”,在日常操作中,相信很多人在JavaScript单元测试的作用是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
      99+
      2024-04-02
    • Python单元测试的作用是什么
      本篇内容主要讲解“Python单元测试的作用是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python单元测试的作用是什么”吧!说明单元测试确保程序模块的行为符合我们设计的测试用例。将来修...
      99+
      2023-06-20
    • Java使用Junit4.jar进行单元测试的方法是什么
      今天就跟大家聊聊有关Java使用Junit4.jar进行单元测试的方法是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、下载依赖包分别下载 junit.jar 以及 hamcr...
      99+
      2023-06-25
    • spring调用bean的方法是什么
      Spring调用Bean的方法通常有以下几种方式: 通过XML配置文件进行配置,在配置文件中声明Bean并指定其相应的属性和方法。...
      99+
      2024-04-09
      spring
    • Spring bean需要依赖注入的原因是什么
      这篇文章主要介绍“Spring bean需要依赖注入的原因是什么”,在日常操作中,相信很多人在Spring bean需要依赖注入的原因是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Spring bean...
      99+
      2023-06-20
    • Golang单元测试中的技巧是什么
      这篇文章主要讲解了“Golang单元测试中的技巧是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Golang单元测试中的技巧是什么”吧!打桩测试当我们在编写单元测试的时候,有时我们非常想...
      99+
      2023-07-05
    • Spring的依赖注入机制是什么
      Spring的依赖注入(Dependency Injection,DI)机制是一种设计模式,用于实现对象之间的解耦和组件的松耦合。它...
      99+
      2023-09-17
      Spring
    • SpringBoot单元测试使用@Test没有run方法的解决方案是什么
      SpringBoot单元测试使用@Test没有run方法的解决方案是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。SpringBoot单元测试使用@Test没有run方法重...
      99+
      2023-06-26
    • spring中bean的初始化方法是什么
      在Spring中,bean的初始化可以通过两种方式来完成:使用@Bean注解的initMethod属性或者实现Initializin...
      99+
      2023-09-21
      spring
    • spring重新加载bean的方法是什么
      Spring重新加载bean的方法有以下几种:1. 使用Spring的热部署功能:在开发环境中,可以配置Spring Boot的de...
      99+
      2023-10-10
      spring bean
    • mybatis TypeHandler注入spring依赖的方法是什么
      这篇文章主要讲解了“mybatis TypeHandler注入spring依赖的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mybatis TypeHandl...
      99+
      2023-06-29
    • SAP EWM入库控制的方法是什么
      这篇文章主要介绍了SAP EWM入库控制的方法是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SAP EWM入库控制的方法是什么文章都会有所收获,下面我们一起来看看吧。   &...
      99+
      2023-06-05
    • SOA架构的域控制器测试解决方案是什么
      SOA架构的域控制器测试解决方案是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。        随着汽车以太网技术成为汽车电子架构的...
      99+
      2023-06-03
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作