spring注解开发

文章详细介绍了Spring框架中使用注解进行bean定义、组件扫描、配置类以及依赖注入的方法。包括@Component、@Controller、@Service、@Repository等衍生注解,以及@@Autowired和@Qualifier的使用。此外,还提到了如何加载propertySource文件和管理第三方bean。
摘要由CSDN通过智能技术生成

注解开发定义bean

  • 使用@Component定义bean

    @Component("bookDao")
    public class BookDaoImpl implements BookDao  {
    }
    @Componpent
    public class BookServiceImpl implements BookService {
    }
    
  • 核心配置文件中通过组件扫描加载bean

    <context:componpent-scan base-package="com.itheima"/>
    

下面注解和上面功能一样只是改变名字方便区分

  • Spring提供@Commponpent注解的三个衍生注解
    • @Controller:用于表现层bean定义
    • @Service:用于业务层bean定义
    • @Repository:用于数据层bean定义
@Repository("bookDao")
public class BookDaoImpl implements BookDao {
}
@Service
public class BookServiceImpl implements BookService {
}

纯注解开发

  • Spring3.0开启了纯注解开发模式,使用Java类替代配置文件,开启了Spring快速开发赛道

  • Java类代替Spring核心配置文件

    @Configuration
    @ComponentScan("com.itheima")
    public class SpringConfig {
    }
    
  • @Configuration注解用于设定当前类为配置类

  • @ComponentScan注解用于设定扫描路径,此注解只能添加一次,多个数据请用数组格式

    @ConponentScan({"com.itheima.service","com.itheima.dao"})
    
  • 读取Spring核心配置文件初始化容器对象切换为读取就Java配置类初始化容器对象

    //加载配置文件初始化容器
    ApplicationContext ctx = new ClassPathXMLApplicationContext("applicationContext.xml");
    //加载配置类初始化容器
    ApplicationContext ctx = new AnnotationConfigApplicationContext(SpringConfig. class);
    

依赖注入

  • 使用@Autowired注解开启自动装配模式(按类型)

    @Service
    public class BookServiceImpl implements BookService {
      @Autowired
      public BookDao bookDao;//可以不用写方法给它赋值
      public void save() {
        System.out.println("book service save");
        bookDao.save();
      }
    }
    
  • 注意:自动装配基于反射设计创建对象并暴力反射对应属性为私有属性初始化数据,因此无需提供setter方法

  • 注意:自动装配建议使用无参构造方法创建对象(默认),如果不提供对应构造方法,请提供唯一的构造方法

  • 使用@Qualifier注解开启指定名称装配bean

    @Service
    public class BookServiceImpl implements BookService {
      @Autowired
      @Qualifier("bookDao")
      private BookDao bookDao;
    }
    
  • 注意:@Qualifier注解无法单独使用,必须配合@Autowired注解使用

  • 使用@Value实现简单类型注入

    @Repository("bookDao")
    public class BookDaoImpl implements BookDao {
      @Value("100")
      //上面的值在加载propertySourve文件后可以直接使用通配符${}获取相应的
      private String connectionNum;
    }
    

加载propertySource文件

  • 加载@PropertySource注解加载properties文件

    @Configuration
    @ComponentScan("com.itheima")
    @PropertySource("claspath:jdbc.properties")
    public class SpringConfig {
    }
    
  • 注意:路径仅支持单一文件配置,多文件请使用数组格式配置,不允许使用通配符*

第三方bean管理

  • 使用@Bean配置第三方bean

    @Configuration
    public class SpringConfig {
      @Bean
      public DataSource dataSource() {
        DruidDataSource ds = new DruidDataSource();
        ds.setDriverClassName("com.mysql.jdbc.Driver");
        ds.setUrl("jdbc:mysql://localhost:3306/spring_db");
        ds.setUsername("root");
        ds.setPassword("root");
        return ds;
      }
    }
    
  • 使用独立的配置类管理第三方bean

      public class JdbcConfig {
      @Bean
      public DataSource dataSource(){
        DruidDataSource ds = new DruidDataSource();
        ds.setDriverClassName("com.mysql.jdbc.Driver");
        ds.setUrl("jdbc:mysql://localhost:3306/spring_db");
        ds.setUsername("root");
        ds.setPassword("root");
        return ds;
      }
    }
    
  • 将独立的配置类加入核心配置

  • 方式一:导入式

    public class JdbcConfig {
      @Bean
      public DataSource dataSource(){
        DruidDataSource ds = new DruidDataSource();
        //相关配置
        return ds;
      }
    }
    
  • 使用@Import注解手动加入配置类到核心配置,此注解只能添加一次,多数据请用数组格式

    @Configuration
    @Import(JdbcConfig.class)
    public class SpringConfig {
    }
    
  • 方式二:扫描式

    @Configuration
    public class JdbcConfig {
      @Bean
      public DataSource dataSource(){
        DruidDataSource ds = new DruidDataSource();
        //相关配置
        return ds;
      }
    }
    
  • 使用@ComponentScan注解扫描配置类所在的包,加载对应的配置类信息

    @Configuration
    @ComponentScan({"com.itheima.config","com.itheima.service","com.itheima.dao"})
    public class SpringConfig {
    }
    

第三方bean依赖注入

  • 简单类型依赖注入

    public class JdbcConfig {
      @Value("com.mysql.jdbc.Driver")
      private String driver;
      public DataSource dataSource(){
        DruidDataSource ds = new DruidDataSource();
        ds.setDriverClassName(driver);
      }
    }
    
  • 引用类型依赖注入

    @Bean
    public DataSource dataSource(BookService bookService){
      System.out.println(bookService);
      DruidDataSource ds = new DruidDataSource();
      //属性设置
      return ds;
    }
    
  • 引用类型注入只需要为bean定义方法设置形参即可,容器会根据类型自动装配对象

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Vighzhen

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

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

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

打赏作者

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

抵扣说明:

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

余额充值