Spring容器描述bean的方式有两种:xml方式、注解方式
修饰bean类型:
-
@Configuration(用于描述配置类)
- @Component(描述通用性组件)
-
@Controller(描述MVC中控制层组件)
-
@Service (描述MVC 中业务层组件)
- @Repository(描述MVC中持久层组件)
/**
* 通过此类取代spring-configs.xml中的配置
* @author 速度
*/
@ComponentScan("com.jt")//配置包扫描路径
@PropertySource("classpath:configs.properties")//引用配置文件
public class AppConfig {//spring-configs.xml
@Bean("dataSource")
public DruidDataSource newDruidDataSource(
//读取配置文件
@Value("${url}")String url,
@Value("${driver}")String driver,
@Value("${jdbcUser}")String username,
@Value("${password}")String password){
DruidDataSource ds=new DruidDataSource();
ds.setDriverClassName(driver);
ds.setUrl(url);
ds.setUsername(username);
ds.setPassword(password);
return ds;
}
}
说明:这些组件实现的功能是一样的,只是应用的业务场景不同
指定Bean作用域以及生命周期方法:
-
@ Scope(描述bean的作用域)
-
@ PostConstruct(描述生命周期开始要调用的初始化的方法)
- @ PreDestroy (描述生命周期结束时要调用的销毁的方法)
/**
* 通过Component注解描述 此对象是一个普通的Bean对象
*/
@Component("openDataSource")
@Scope("singleton") // 单例、多例:默认singleton(单例),prototype(多例)
@Lazy(true) // 懒加载:默认true(延迟加载),false(立刻加载)
public class OpenDataSource {
/** 生命周期初始化方法 */
@PostConstruct
public void init() {
System.out.println("OpenDataSource.init()");
}
/** 生命周期销毁方法 */
@PreDestroy
public void close() {
System.out.println("OpenDataSource.close()");
}
}
说明:描述生命周期方法的注解应用时应在JDK1.7以上版本
自动装配注解(为属性注入值)
-
@Autowire (一般修饰构造方法或set方法或属性,默认按类型装配)
-
@Qualifier (配合Autowire注解,按名字进行装配,尤其是出类型相同的bean时,可以指定具体bean)
@Service
public class SysConfigServiceImpl implements SysConfigService{
@Autowired //按照类型(属性类型、参数类型)进行查找,找出具有相同类型的数据
@Qualifier("configDao") //从相同的类型中,按照名字(属性名、set方法参数名、构造方法参数名)进行注入
private SysConfigDao sysConfigDao;
}
-
@Resource (一般修饰set方法或属性,默认按名字装配)
@Controller
public class SysConfigController {
//默认先按属性名进行依赖查找,找不到则按类型进行查找.
/** 根据属性进行依赖注入:
先看属性名是否相同 然后根据属性的类型进行依赖注入
属性名不同 查看唯一与之属性类型相同的属性是否存在 若存在则注入
根据set方法进行依赖注入:
先按方法名进行依赖注入
若方法名不相同,则按参数类型进行依赖注入
若参数类型不唯一,则按照参数名进行依赖注入
if (名字相同) {
if (类型相同) {
return "注入成功";
} else {
return "注入失败";
}
} else if (类型相同) {
if (唯一) {
return "注入成功";
} else {
return "注入失败";
}
}*/
@Resource
private SysConfigService sysConfigService;
}
说明:无论默认按类型还是名字进行装配,在没有找到对应名字或类型对象时底层还可能转换机制.