一、 注解开发
@Autowired:相当于在spring的配置文件中按照类型自动装配
@Qualifier:指定名称,按照名称来查找,通常和@Autowired注解搭配使用
@Resource:默认按照名称自动装配,如果名称找不到的话,就按照类型动装配
1.定义一个bean
@Component("bookDao")
public class BookDaoImpl implements BookDao {
public void save() {
System.out.println("BookDao save...");
}
}
在配置文件中就可以删除了
但是要让配置文件知道我定义了这个bean
2.使用context命名空间进行包扫描
<context:component-scan base-package="com.itheima.dao.impl"/>
3.测试:
public static void main(String[] args) {
ApplicationContext applicationContext=new ClassPathXmlApplicationContext("SpringConfig.xml");
BookService bean = applicationContext.getBean(BookService.class);
bean.save();
}
Spring提供@Component 注解的三个衍生注解
@Component: 标注一个类为Spring容器的Bean
@Controller:用于表现层bean定义
@Service:用于业务层bean的定义
@Repository:用于数据层bean的定义
二、纯注解开发模式
1.创建一个配置类(SpringConfig)
@Configuration
@ComponentScan("com.itheima.service.impl")
public class SpringConfig {
}
使用@Configuration注解消除配置文件中的下面这段代码
使用@ComponentScan消除消除配置文件中的下面这段代码
@Configuration注解用于设定当前类为配置类
@ComponentScan注解用于设定扫描路径,此注解只能添加一次,多个数据请用数组格式
2.加载配置类
ApplicationContext ctx=new AnnotationConfigApplicationContext(SpringConfig.class);
3.测试
public static void main(String[] args) {
ApplicationContext applicationContext=new AnnotationConfigApplicationContext(SpringConfig.class);
BookService bean = applicationContext.getBean(BookService.class);
bean.save();
}
三、bean的作用范围与生命周期管理
@Scope(“singleton”)单例模式
@Scope(“prototype”)非单例模式
生命周期:
@PostConstruct初始化
@PreDestroy销毁
注意:使用JDK11需要导入依赖坐标
<dependency>
<groupId>javax.annotation</groupId>
<artifactId>javax.annotation-api</artifactId>
<version>1.3.2</version>
</dependency>
使用举例:
@Component
public class BookServiceImpl implements BookService {
public void save() {
System.out.println("BookService!");
}
@PostConstruct
public void init(){
System.out.println("初始化");
}
@PreDestroy
public void destory(){
System.out.println("销毁");
}
}
自动装配
使用@Autowired自动装配
默认按照类型装配
当有多个BookDao对象时,可以设置id通过id区分
@Service
public class BookServiceImpl implements BookService {
@Autowired
@Qualifier("bookDao1")//使用id区分,Qualifier无法独立使用要配合@Autowired
private BookDao bookDao;
public void setBookDao(BookDao bookDao) {
this.bookDao = bookDao;
}
public void save() {
System.out.println("book service save....");
}
}
因为自动装配是基于反射设计创建对象并暴力反射对应属性为私有属性初始化数据,因此无需提供setter方法也可以实现自动装配
自动装配建议使用无参构造方法创建对象,如果不提供对应的构造方法,请提供唯一的构造方法
@Service
public class BookServiceImpl implements BookService {
@Autowired
@Qualifier("bookDao1")
private BookDao bookDao;
public BookServiceImpl() {
}
public void save() {
System.out.println("book service save....");
}
}
使用@Value实现简单类型注入
@Value("张三")
private String name;
加载Properties
使用@PropertySource
在配置类中
properties文件内容
使用占位符设置name
如果要加载多个Properties文件
设置为集合的格式
@PropertySource({"jdbc2.properties"})
四、注解管理第三方bean
使用@Bean配置第三方Bean
并且不要写在SpringCongfig配置类中
创建一个JdbcConfig类
public class JdbcConfig {
//1.定义一个方法获得要管理的对象
//2.添加@Bean,表示当前方法的返回值是一个bean
@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("20020630");
return ds;
}
}
在SpringConfig类中使用@Import导入这个类
@Configuration
@Import(JdbcConfig.class)
public class SpringConfig {
}
简单类型依赖注入
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("20020630")
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;
}
}
引用类型依赖注入
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("20020630")
private String password;
@Bean
public DataSource dataSource(BookDao bookDao){
//自动装配
System.out.println(bookDao);
DruidDataSource ds=new DruidDataSource();
ds.setDriverClassName(driver);
ds.setUrl(url);
ds.setUsername(username);
ds.setPassword(password);
return ds;
}
}