• Spring IOC 常用注解与使用


    @Component

    注解@component代表spring ioc 会把这个类扫描生成Bean实例

    @Component
    public class Role{
        @Value("1")
        private Long id;
        @Value("role_name_1")
        private String roleName;
        @Value("role_note_1")
        private String note;
        /***setter and getter****/
    }
    

    @Autowired

    注解@Autowired代表在spring ioc 定位所有的Bean后,这个字段需要按类型来进行注入。

    @Component
    public class RoleImpl_1 implements RoleServer{
        @Autowired
        private Role role = null;
        
        public .....
    }
    

    @Qualifier

    ​ 如果一个接口被两次实现,则使用@Autowired注解来进行该接口注入会产生异常,因为@Autowired无法确定要使用的是哪一个实现类。可以使用@Qualifier注解来进行歧义消除。

    @Component
    public class RoleController{
        @Autowired
        @Qualifier("roleImple_2")
        private RoleServer server = null;
        
        public .....
    }
    

    @Bean

    ​ 在注解都都是通过@component来进行装配Bean,但是@Component只能注解在类上,无法注解到方法上。而注解@Bean可以注解到方法上

    @Bean(name = "dataSource")
    public DataSource getDataSource(){
        Properties props = new Properties();
        props.setProperty("driver","com.mysql.cj.jdbc.Driver");
        props.setProperty("url","jdbc:mysql://localhost:3306/db");
        ...
        try{
            dataSource = BasicDataSourceFactory.createDataSource(props);
        }catch(Execption e){
            e.printStackTrace();
        }
        return dataSource;
    }
    
    @Component
    public class RoleController{
        @Autowired(name = "dataSource")
        private DataSource dataSource = null;
        
        public .....
    }
    

    @ImportResource

    ​ 如果我们将DataSource使用xml配置文件来进行配置,我们就无法使用注解@Bean来进行装配。这时注解@ImportResource可以进行混合装配(将第三方的xml引入进来进行装配)。

    <!--dbSource.xml-->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
    	<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
    	<property name="url" value="jdbc:mysql://localhost:3306/db"/>
        .......
    </bean>
    
    @ComponentScan(basePackages={"com.test"})
    @ImportResource({"classpath:dbSource.xml"})  //将dbSource.xml配置文件装配到Ioc中来
    public class ApplicationConfig{
    }
    
    @Component
    public class RoleController{
        @Autowired
        private DataSource dataSource = null;
      
        public .....
    }
    

    如果有多个xml文件,我们都想引用进来,可以在dbSource.xml配置文件中使用import元素来加载它

    <!--spring-dataSource.xml-->
    ...........
    
    <!--dbSource.xml-->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
    	<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
    	<property name="url" value="jdbc:mysql://localhost:3306/db"/>
        .......
    </bean>
    <import resourse="spring-dataSource.xml"/>
    

    @Profile

    ​ 可以解决不同环境的切换需求,例如开发环境和测试环境不同,我们来看代码操作。

    @Component
    public class ProfileDataSource{
        //开发环境
        @Bean(name = "devDataSource")
        @Profile("dev")
        public DataSource getDevDataSource(){
            ......
        }
        
        //测试环境
        @Bean(name = "testDataSource")
        @Profile("test")
        public DataSource getTestDataSource(){
            ......
        }
    }
    

    当启动Java配置Profile时,可以发现两个Bean并不会加载到IOC容器中,需要自行激活Profie。我们可以使用JVM启动目录或在集成测试环境中使用@ActiveProfiles进行定义

    //使用@ActiveProfiles激活Profie
    @RunWith(SpringJunit4ClassRunner.class)
    @ContextConfiguration(classes=ProfileTest.class)
    @ActiveProfiles("dev")  //激活开发环境的Profile
    public class ProfileTest{
        
    }
    
    //使用JVM参数激活Profie
    JAVA_OPTS="-Dspring.profiles.active=test"
    

    @PropertySource

    可以使用注解@PropertySource来加载属性文件(properties)。

    # dataSource.properties
    jdbc.database.driver=com.mysql.cj.jdbc.Driver
    jdbc.database.url=jdbc:mysql://localhost:3306/db
    .......
    
    @Configuration
    @PropertySource(value = {"classpath:dataSource.properties"},{ignoreResourceNotFound=true})
    public class ApplicationConfig{
        
    }
    

    ignoreResourceNotFound=true,如果找不到该属性文件则忽略它。

  • 相关阅读:
    chat GPT第一讲
    Workfine新手入门:日期间隔函数
    【PAT(甲级)】1051 Pop Sequence(栈的进出使用)
    Android 进入 Activity 时禁止弹出输入法
    教你轻松理解Go Ticker的用法和实现原理
    一种用于医学图像分割的多源模型适应方法
    Maven:命令行
    Linux系统下配置LEMP
    18.2.3 删除分区
    SQL语句知识大全
  • 原文地址:https://www.cnblogs.com/MineLSG/p/16343082.html