Bean基本注解开发
注解代替<bean>
@Component:
对要加入bean容器的类使用@Component注解,defalut值表示加入bean容器后的beanName,如果不指定defalut的话,bean容器会默认将类名作为beanName(userDaoImpl):
在xml配置文件中扫描@Component注解:
使用:
<bean>标签中其他属性的注解配置:
@Component衍生的其他三个注解:
为了开发规范,属于哪一层的就用哪一层的注解,如果某个bean哪一层都不是,就使用@Component
Bean依赖注入注解开发
@Value:
当然我们也可以使用stl表达式动态地从配置文件中取得值进行一个@Value的注入
在xml配置文件中将jdbc.properties文件加载进Spring容器,这样Spring容器中就有jdbc配置文件的键值对了:
使用stl表达式动态获取:
@Autowired和@Qualifier
有时我们除了要注入简单类型外,还要注入引用类型,@Autowired根据类型(byType)进行注入,如果Spring容器中同一类型的Bean有多个,会继续根据名字进行二次匹配,如果不匹配才报错:
@Qualifier与@Autowired配合使用,可以根据名称注入相应的Bean:
@Resource:
@Resource注解是javax的注解,不是Spring提供的,但是Spring内部对@Resource进行了解析,使得@Resource也可以根据类型或名称注入:
根据类型注入:
使用name属性指定名称注入:
@Autowired拓展
@Autowired对方法形参进行注入时,对方法名没有要求,只关注形参类型和名字:
如下Spring容器中有两个类型为userDao的Bean
第一个@Autowired会先根据类型去Spring容器中匹配,但是出现了多个UserDao,就根据名字取匹配;第二个@Autowired表示匹配Spring容器中所有的UserDao注入到List集合中去。
非自定义Bean的配置
如果非自定义的Bean需要参数,该怎么注入参数还是怎么注入参数,简单类型用@Value,引用类型用@Autowired,要根据名字注入引用类型就多用个@Qualifier,如下:
这里的stl表达式${jdbc.driver}是已经被加载进入Spring容器的jdbc配置类中的键
Bean配置类的注解开发——取消xml配置文件,进入纯注解开发
property-placeholder和component-scan 以及 配置文件的注解替代
这是原本xml配置文件的信息,现在所有的bean标签都可以被注解替代了,剩下的也可以完全被注解替代
定义一个配置类,
@Configuration标注当前类是一个配置类,同时@Configuration内还有@Component注解,这样一个@Configuration就可以让Spring容器扫描到了 ;
@ComponentScan代替配置文件中扫描包的部分,如果要扫描多个包可以使用数组的写法,如:@ComponentScan(basePackages = {"com.itheima","xxx"}),basePackages可省略;
@PropertySource代替配置文件中扫描配置文件的部分,如果要扫描多个配置文件可以使用数组的写法。
但是加载类就不同于之前基于xml的Spring开发了,得扫描配置类了
ApplicationContext接口有两个实现类,一个是ClassPathXmlApplicationContext,也就是加载xml配置文件进入Spring容器用的类,还有一个AnnotationConfigApplicationContext,是加载@Configure配置类
其他xml配置标签,如<import>标签的注解替代
使用@Import注解,将其他配置类加载进主配置类
Spring配置其他注解(不常用)
注解方式整合Mybatis
@Bean将非自定义的数据源加入到Spring容器中,相当于xml文件中配置数据源的部分
@Bean将SqlSessionFactoryBean加入到Spring容器中,并注入数据源,这里不用@Value对DataSource进行注入也可以,Spring容器会扫描到我们配置的数据源
最后在配置类上加上@MapperScan,属性为Mapper包的路径,相当于xml文件中配置Mapper包扫描的部分:
配置完成之后就完成了Spring整合Mybatis了,这样之后就关注mapper接口和映射文件的编写即可:
使用mapper的时候直接注入即可: