依赖注入

自动装配

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

@Service
public class BookServiceImpl implements BookService{
    @Autowired
    // @Qualifier("bookDao")
    private BookDao bookDao;

    // @Autowired // 放set方法也能用
    // public void setBookDao(BookDao bookDao){  // 不需要setter方法也能注入
    //     this.bookDao = bookDao;
    // }

    public void save(){
        System.out.println("book service save ...");
        bookDao.save();
    }
}
@Repository
public class BookDaoImpl implements BookDao{
    public void save(){
        System.out.println("book dao save ...");
    }
}

有多个数据层时,无法按类型装配,需要在@Repository()中指定名称,在需要注入的地方使用@Qualifier()输入名称指定要注入的Bean

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

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

@Service
public class BookServiceImpl implements BookService{
    @Autowired
    @Qualifier("bookDao")
    private BookDao bookDao;

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

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

@Repository
public class BookDaoImpl implements BookDao{
    @Value("bookname")
    private String name;

    public void save(){
        System.out.println("book dao save ..." + name);
    }
}

加载properties文件

使用@PropertySource注解加载properties文件

@Configuration
@ComponentScan("com.xxx")
@PropertySource("classpath:jdbc.properties") // 不支持通配符 *.properties
// @PropertySource({"jdbc.properties", "jdbc2.properties"}) // 多个配置文件使用数组列出
public class SpringConfig{

}

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

public class BookDaoImpl implements BookDao{
    @Value("${name}")
    private String name;

    public void save(){
        System.out.println("book dao save ..." + name);
    }
}
// jdbc.properties
name=bookname