使用注解开发
spring4以后,使用注解开发,必须要保证aop的包导入了
使用注解需要导入context约束,增加注解支持
<context:annotation-config/>
<context:component-scan base-package="com.pyt"/>
@Component
bean和属性的注入:
@Component //相当于<bean id="user" class="com.pyt.pojo.User"/>
public class User {
@Value("pyt")
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
衍生的注解
@Component有几个衍生的注解,按照MVC三层架构分层如下:
dao @Repository
service @Service
controller @Controller
这四个注解功能一样,均代表将某个类注册到Spring中,装配Bean
作用域
Scope(“singleton” / “prototype”) 设置为单/多例模式
小结
xml与注解:
xml更加万能,适用于任何场合,维护简单方便
注解不是自己的类使用不了,维护相对复杂
xml与注解最佳实践:
xml用来管理bean
注解只负责完成属性的注入
使用过程中只需要注意:开启注解支持让注解生效;扫描包
全注解开发
使用java的方式配置Spring
JavaConfig是Spring的一个子项目,在spring4之后成为了核心功能。
MyConfig类
@Configuration也会被容器托管,注册到容器中,因为他本来就是一个@Component
@Configuration代表这是一个配置类,相当于之前的beans.xml
@Configuration
@ComponentScan("com.pyt")
public class MyConfig {
/**
* @Bean注册一个bean,相当于之前的一个bean标签
* 该方法名相当于bean标签中的id
* 返回值相当于bean标签的class属性
* @return
*/
@Bean
public User getUser(){
return new User();
}
}
如果完全使用配置类的方式进行开发,我们只能通过AnnotationConfig上下文来获取容器,通过配置类的class对象加载。
获取容器(测试类):
public class MyTest {
public static void main(String[] args) {
ApplicationContext context = new AnnotationConfigApplicationContext(MyConfig.class);
User user = context.getBean("getUser", User.class);
System.out.println(user.getName());
}
}
可以将多个配置类导入成为一个配置类
@Import(MyConfig2.class)
public class MyConfig {
@Bean
public User getUser(){
return new User();
}
}
纯java配置在SpringBoot中随处可见