IOC注解(获取对象存入核心容器中管理):4种
1.Controller 注解 建议在表现层使用
2.Service 注解 建议在业务层使用
3.Repository 注解 建议在持久层使用 英文意思:仓库
4.Component 注解 用于其他地方 英文意思:组件
使用注解IOC时,默认的id为类名第一个字母小写 也可以在注解中使用value属性命名id
使用IOC注解需要的步骤:
1. 添加一个约束信息 context
2. 添加包扫描(因为我们的注解是写在类上的,所以要扫描包里面的类,才能加载类上的注解)
3. 要让spring容器创建和管理哪个对象,那么就给哪个类添加Component注解
如果这个类使我们自己写的类,那么我们就可以使用注解的方式进行IOC
但是如果这个类是第三方框架的类,那么我们就无法使用注解的方式进行IOC,只能使用配置文件
IOC注解的其他注解:
@scope 注解 相当于<bean>标签中的scope属性,其用法代表意思一致
singleton:单例(默认)
prototype:多例 (当ioc对象时pojo的时候就需要用他)
@@PostConstruct 注解 相当于xml中<bean>标签的init-method属性 初始化调用的方法
@PreDestroy 注解 相当于xml中<bean>标签的destroy-method属性 销毁时调用的方法
DI依赖注入 注解 此处就不是使用构造方法和set方法注入,而是通过*暴力反射*,直接由底层给成员变量赋值
1.Autowired 注解 只有一个时,直接注入该对象,若有多个该类型对象默认只能匹配id为变量名的对象 英文意思:自动装配
装配规则:
1.1 如果Spring核心容器只有一个该类型对象,那么直接注入该对象
1.2 如果spring核心容器有多个给类型对象,先根据属性名匹配id,若有则直接注入该对象
1.3 如果spring核心容器有多个给类型对象,根据属性名没有匹配的id,则用Qualifier注解指定id
2.Qualifier 注解 和Autowired配合使用,用来指定装配的id 当自动装配找到不到时联合使用 英文意思:限定符
3.Resource 注解 有name属性可以指定装配的id 相当于前两个的结合使用 当name没有值时就按照变量名匹配
4.value 注解 用于注入简单类型的数据,那么就得使用@Value注解 (通常是结合配置文件一起使用) 其值可以是值也可以是表达式
使用纯注解时需要的一些注解(也就是定义一个配置文件类):
@Configuration 配置类注解 指定当前类是一个spring配置类,当创建容器时会从该类上加载注解
此时创建核心容器就需要AnnotationApplicationContext(类.class)了
@ComponentScan 相当于xml中的包扫描标签 指定spring在初始化容器时要扫描的包 里面属性值为包名
@Bean 表明使用此***方法***创建一个对象,并且放入spring容器 详单与bean标签 默认的name属性为对象id 方法的形参是要自动注入的 @Qualifier注解
使用配置类配置的代码:
@Import 用于导入其他配置类,在引入其他配置类时,可以不用再写@Configuration注解。(主要便于模块化)
@PropertySource 用于加载.properties文件中的配置 ${key}可以获取key对应的值 和@value搭配使用
上述五个注解的综合使用,完全注解开发 代码如下
//spring的配置类 扫描包 导入配置类
@Configuration
@ComponentScan("com.itheima")
@Import(JdbcConfiguration.class)
public class SpringConfiguration {
@Bean("queryRunner")
public QueryRunner createQueryRunner(@Qualifier(value ="dataSource") DataSource dataSource){
//此方法就是将id为dataSource的对象 赋值给了形参
return new QueryRunner(dataSource);
}
}
//用来创建dataSource 取消utils
@PropertySource(value = {"classpath:jdbc.properties"})
public class JdbcConfiguration {
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.username}")
private String username;
@Value("${jdbc.password}")
private String password;
//创建数据源 也就是将数据源信息封装给datasource
@Bean("dataSource")
public DataSource createDataSource(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setUrl(url);
dataSource.setDriverClassName(driver);
dataSource.setUsername(username);
dataSource.setPassword(password);
return dataSource;
}
}