注解开发定义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定义方法设置形参即可,容器会根据类型自动装配对象