Spring注解开发详解

前言

《Spring快速入门详解》中主要介绍了通过xml配置文件的方式进行开发,其实还可以通过注解方式进行开发。
Spring3.0升级了纯注解开发模式,使用Java类替代配置文件,开启了Spring快速开发赛道。本文主要详细讲解Spring注解方式开发。

注解开发

1. 快速入门

1.1 注解开发定义bean

1.1.1 使用@Component定义bean
@Component("bookDao")
public class BookDaoImpl implements BookDao {
}
@Component
public class BookServiceImpl implements BookService {
}

注意:如果没有定义名称,那么只能通过类型获取。

1.1.2 核心配置文件中通过组件扫描加载bean
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:context="http://www.springframework.org/schema/context"
       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
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">

  <context:component-scan base-package="com.hao"/>
</beans>

扫描base-package包下的所有添加@Component注解的类

1.1.3 Spring提供@Component注解的三个衍生注解

@Controller:用于表现层bean定义
@Service:用于业务层bean定义
@Repository:用于数据层bean定义

@Repository("bookDao")
public class BookDaoImpl implements BookDao {
}
@Service
public class BookServiceImpl implements BookService {
}

1.2 纯注解开发

Spring3.0升级了纯注解开发模式,使用Java类替代配置文件,开启了Spring快速开发赛道。本文主要详细讲解Spring注解方式开发。

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

xml配置文件被Java类代替,创建Java类如下:

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

@Configuration注解用于设定当前类为配置类。
@ComponentScan注解用于设定扫描路径,此注解只能添加一次,多个数据请用数组格式。

1.2.2 读取Spring核心配置文件初始化容器对象切换为读取Java配置类初始化容器对象
// 加载配置文件初始化容器
ApplicationContext cxt = new ClassPathXmlApplicationContext("applicationContext.xml");
// 加载配置类初始化容器
ApplicationContext cxt = new AnnotationConfigApplicationContext(SpringConfig.class);

2. bean管理

2.1 bean作用范围

2.1.1 使用@Scope定义bean作用范围
@Repository
@Scope("singleton")
public class BookDaoImpl implements BookDao {
}

@Scope默认是单例singleton,可以不写,如果需要非单例模式,修改为prototype即可。

2.2 bean生命周期

2.2.1 使用@PostConstruct、@PreDestroy定义bean生命周期
@Repository
public class BookDaoImpl implements BookDao {

    public BookDaoImpl() {
        System.out.println("book dao constructor...");
    }
    @PostConstruct
    public void init() {
        System.out.println("book dao init...");
    }
    @PreDestroy
    public void destroy() {
        System.out.println("book dao destroy...");
    }
}

自定义init()destroy()方法添加相应注解即可。

3. 依赖注入

3.1 自动装配

3.1.1 使用@Autowired注解开启自动装配模式(按类型)
@Service
public class BookServiceImpl implements BookService {
    @Autowired
    private BookDao bookDao;
    public void setBookDao(BookDao bookDao) {
        this.bookDao = bookDao;
    }
    @Override
    public void save() {
        System.out.println("book service save...");
        bookDao.save();
    }
}

注意:自动装配基于反射设计创建对象并暴力反射对应属性为私有属性初始化数据,因此无需提供setter方法
注意:自动装配建议使用无参构造方法创建对象(默认),如果不提供对应构造方法,请提供唯一的构造方法

3.1.2 使用@Qualifier注解开启指定名称装配bean
@Service
public class BookServiceImpl implements BookService {
    @Autowired
    @Qualifier("bookDao")
    private BookDao bookDao;
} 

注意@Qualifier注解无法单独使用,必须配合@Autowired注解使用

3.1.3 使用@Value注解实现简单类型注入
@Repository("bookDao")
public class BookDaoImpl implements BookDao {
    @Value("it_hao528")
    private String name;
    @Override
    public void save() {
        System.out.println("book dao save..." + name);
    }
}

3.2 加载properties文件

3.2.1 使用@PropertySource注解加载properties文件
@Configuration
@ComponentScan({"com.hao"})
@PropertySource({"jdbc.properties"})
public class SpringConfig {
}

注意:路径仅支持单一文件配置,多文件请使用数组格式配置,不允许使用通配符*

4. 第三方bean管理

这里还是以druid为例。

4.1 第三方bean管理

4.1.1 使用@Bean注解配置第三方bean
  1. 定义一个方法获得要管理的对象
  2. 添加@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("123456");
        return ds;
    }
}
4.1.2 使用独立的配置类管理第三方bean
  1. 创建一个独立的三方配置类
  2. 定义一个方法获得要管理的对象
  3. 添加@Bean,表示当前方法的返回值是一个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("hao123456");
        return ds;
    }
}
4.1.3 将独立的配置类加入核心配置
4.1.3.1 方式一:导入式
public class JdbcConfig {
    @Bean
    public DataSource dataSource() {
        DruidDataSource ds = new DruidDataSource();
        /* 相关配置 */  
        return ds;
    }
}

使用@Import注解手动加入配置类到核心配置,此注解只能添加一次,多个数据请用数组格式。

@Configuration
@Import({JdbcConfig.class})
public class SpringConfig {
}
4.1.3.2 方式二:扫描式
@Configuration
public class JdbcConfig {
    @Bean
    public DataSource dataSource() {
        DruidDataSource ds = new DruidDataSource();
        /* 相关配置 */  
        return ds;
    }
}

使用@ComponentScan注解扫描配置类所在的包,加载对应的配置类信息。

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

4.2 第三方bean依赖注入

4.2.1 简单类型依赖注入
public class JdbcConfig {
    @Value("com.mysql.jdbc.Driver")
    private String driver;
    @Value("jdbc:mysql://localhost:3306/spring_db")
    private String url;
    @Value("root")
    private String username;
    @Value("123456")
    private String password;
    @Bean
    public DataSource dataSource() {
        DruidDataSource ds = new DruidDataSource();
        ds.setDriverClassName(driver);
        ds.setUrl(url);
        ds.setUsername(username);
        ds.setPassword(password);
        return ds;
    }
}

简单类型注入使用@Value注解给属性设置数据值。

4.2.2 引用类型依赖注入
public class JdbcConfig {
    @Bean
    public DataSource dataSource(BookDao bookDao) {
        System.out.println(bookDao);
        /* 属性设置 */
        return ds;
    }
}

引用类型注入只需要为bean定义方法设置形参即可,容器会根据类型自动装配对象。

5. XML配置与注解配置比较

在这里插入图片描述

总结

以上就是关于Spring注解开发详解的全部内容。
个人的小观点:
使用XML配置开发管理比较直观,所有bean都在配置文件中进行管理,但是如果管理的bean比较多,配置文件代码会比较多,看起来会比较臃肿。
使用注解开发Java类配置不需要太多代码,除三方外的所有bean都分散到相应的接口类中使用注解管理,这样虽然代码看起来比较清爽,但是管理起来可能会因为比较分散而稍麻烦一些。

如果有什么问题,我们可以一起交流讨论解决。

最后,希望可以帮助到有需要的码友。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

it_hao528

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

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

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

打赏作者

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

抵扣说明:

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

余额充值