Spring-注解开发

推荐先阅读Spring全家桶

定义bean

使用@Component定义bean

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

核心配置文件中通过组件扫描加载bean

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

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

  • @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核心配置文件

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

TO:

@Configuration
@ComponentScan("com.zhangxin")
public class SpringConfig {
}

@Configuration注解用于设定当前类为配置类

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

@ComponentScan({"com.zx.service","com.zx.dao"})

bean生命周期

使用@PostConstruct@PreDestroy 定义初始化方法、销毁方法

@Repository
public class BookDaoImpl implements BookDao {
public void save() {
System.out.println("book dao save ...");
}
// 在构造方法之后执行,替换 init-method
@PostConstruct
public void init() {
System.out.println("init ...");
}
// 在销毁方法之前执行,替换 destroy-method
@PreDestroy
public void destroy() {
System.out.println("destroy ...");
}
}

依赖注入

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

@Service
public class BookServiceImpl implements BookService {
@Autowired
private BookDao bookDao;
// public void setBookDao(BookDao bookDao) {
// this.bookDao = bookDao;
// }
}

自动装配基于反射设计创建对象并通过暴力反射为私有属性进行设值,因此无需提供setter方法

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

使用@Qualifier注解指定名称装配(必须配合@Autowired使用)

@Autowired
@Qualifier("bookDao1")
private BookDao bookDao;

加载properties文件

使用@PropertySource注解加载properties文件

@Configuration
@ComponentScan("com.zx")
@PropertySource("classpath: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;
}
}

将独立的配置类加入核心配置

方式1:导入式

public class JdbcConfig{
@Bean
public DataSource dataSource(){
DruidDataSource ds = new DruidDataSource();
// 相关配置
return ds;
}
}

使用@Import注解手动加入配置类到核心配置,多数据用数组格式

@Configuration
@Import(JdbcConfig.class)
public class SpringConfig{
}

方式2:扫描式

@Configuration
public class JdbcConfig{
@Bean
public DataSource dataSource(){
DruidDataSource ds = new DruidDataSource();
// 相关配置
return ds;
}
}

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

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

简单类型依赖注入

使用@Value注解引入值

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("password")
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;
}
}

引用类型依赖注入

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

步骤1:在SpringConfig中扫描BookDao

扫描的目的是让Spring能管理到BookDao,也就是说要让IOC容器中有一个bookDao对象

@Configuration
@ComponentScan("com.zx.dao")
@Import({JdbcConfig.class})
public class SpringConfig {
}

步骤2:在JdbcConfig类的方法上添加参数

@Bean
public DataSource dataSource(BookDao bookDao){
System.out.println(bookDao);
DruidDataSource ds = new DruidDataSource();
// 属性设置
return ds;
}

xml配置和注解配置比较

功能 xml配置 注解
定义bean bean标签
- id属性
- class属性
@Component
- @Controller
- @Service
- @Repository
@ComponentScan
设置依赖注入 setter注入(set方法)
- 引用/简单
构造器注入(构造方法)
- 引用/简单
自动装配
@Autowired
- @Qualifier
@Value
配置第三方bean bean标签
静态工厂、实例工厂、FactoryBean
@Bean
作用范围 - scope属性 @Scope
生命周期 标准接口
- init-method
- destory-method
@PostConstructor
@PreDestory