小言_互联网的博客

注解方式管理Bean

474人阅读  评论(0)

1.注解方式创建对象IOC

导入依赖 aop
@Component(父注解) 放在类上,用于标记,告诉spring当前类需要由容器实例化bean并放入容器中
该注解有三个子注解
@Controller 用于实例化controller层bean
@Service 用于实例化service层bean
@Repository 用于实例化持久层bean
当不确定是哪一层,就用Component
这几个注解互相混用其实也可以,但是不推荐

第一步:在applicationContext.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:p="http://www.springframework.org/schema/p"
       xmlns:c="http://www.springframework.org/schema/c"
       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
       http://www.springframework.org/schema/context/spring-context.xsd
">
    <!--添加注解扫描,扫描指定的包,将包中的所有有注解的类实例化
    base-package 后面放要扫描的包
    如果有多个包需要扫描,可以使用逗号隔开  com.msb.bean,com.msb.service
    或者可以写上一层包路径  com.msb
    可以通过注解指定bean的id@Component("user1")
    如果不指定,则id默认是 类名首字母小写
    -->
    <context:component-scan base-package="com.msb.bean"></context:component-scan>
</beans>

 

第二步:在类上添加注解,让spring容器给我们创建bean实例并存储于容器中

package com.msb.bean;
import org.springframework.stereotype.Component;
/**
 * @Author: Ma HaiYang
 * @Description: MircoMessage:Mark_7001
 */
@Component(value = "user1")
public class User {
   
}

测试代码

package com.msb.test;
import com.msb.bean.User;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
 * @Author: Ma HaiYang
 * @Description: MircoMessage:Mark_7001
 */
public class Test1 {
   
    @Test
    public void testGetBean(){
   
        ApplicationContext context =new ClassPathXmlApplicationContext("applicationContext.xml");
        User user = context.getBean("user1", User.class);
        System.out.println(user);
    }
}

 

组件扫描配置注解识别

<!--
    use-default-filters="false"
    默认值为true 代表使用默认的扫描过滤器
    默认的扫描过滤器会识别并包含 @Component @Controller @Service @Repository 四个注解
    不使用默认的filter,使用我们自己的filter
    -->
    <!--控制只扫描Controller注解-->
    <context:component-scan base-package="com.msb" use-default-filters="false">
        <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>
    <!--控制不扫描Controller注解-->
    <context:component-scan base-package="com.msb" use-default-filters="true">
        <context:exclude-filter  type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>

2.注解方式依赖注入DI

@Autowired 根据属性数据类型自动装配
@Qualifier 根据属性名称注入依赖
@Resources 可以根据类型,也可以根据名称注入
@Value 注入普通数据类型(8+String)

项目结构如下

applicationContext.xml中配置包扫描和读取属性配置文件

Dao层
接口

实现类

让容器扫描 Service层,实例化对象
接口

实现类

package com.msb.service.impl;
import com.msb.dao.UserDao;
import com.msb.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
/**
 * @Author: Ma HaiYang
 * @Description: MircoMessage:Mark_7001
 */
@Service
public class UserServiceImpl implements UserService {
   
    /*
    *@Autowired
    * 根据类型到容器中去寻找对应的对象,找到后给当前属性赋值
    * 不需要依赖 set方法
    * 属性类型可以是接口,会自动匹配对应的实现类对象
    * @Autowired配合 @Qualifier,可以通过名称指定注入的对象
    *
    * @Resource 如果不配置name 那么就是根据类型注入
    * @Resource(name="userDaoImplB") 配置name,就是根据名称注入
    *
    *
    * @Resource  是JDK中javax包的注解
    * @Autowired 和 @Qualifier 是spring中的注解
    *
    * @Value 可以个普通属性赋值
    * @Value 可以使用${}这种表达式获取系统的变量值
    *        或者是.properties属性配置文件中的值
    *
    * */
    //@Autowired
    //@Qualifier("userDaoImplA")
    //@Qualifier("userDaoImplB")
    //private UserDao userDao ;
    @Resource(name="userDaoImplB")
    private UserDao userDao ;
    @Value("${username}")
    private String sname;
    @Value("boy")
    private String sgender;
    @Value("${age}")
    private Integer sage;
    @Override
    public void add() {
   
        System.out.println("userServiceImpl add ... ... ");
        System.out.println(sname);
        System.out.println(sgender);
        System.out.println(sage);
        userDao.add();
    }
}

 

测试代码

package com.msb.test;
import com.msb.service.UserService;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
/**
 * @Author: Ma HaiYang
 * @Description: MircoMessage:Mark_7001
 */
public class Test1 {
   
    @Test
    public void testGetBean(){
   
        ApplicationContext context =new ClassPathXmlApplicationContext("applicationContext.xml");
        UserService userService = context.getBean("userServiceImpl", UserService.class);
        userService.add();
    }
}

 

3.完全使用注解(了解)

创建配置类,替代XML配置文件

测试代码

 @Test
    public void testGetBean2(){
   
        ApplicationContext context=new AnnotationConfigApplicationContext(SpringConfig.class);
        UserServiceImpl userService = context.getBean("userServiceImpl", UserServiceImpl.class);
        userService.add();
    }

转载:https://blog.csdn.net/m0_37135879/article/details/128764158
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场