在Spring4之后,要使用注解开发,必须要保证aop的包导入了
使用注解需要导入context约束,增加注解的支持
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans https://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd"> <context:annotation-config/> </beans>
bean
属性如何注入
<!-- 指定要扫描的包,这个包下的注解就会生效--> <context:component-scan base-package="com.kuang"/>
//@Component 等价于<bean id="user" class="com.kuang.dao.User"> ,就不用在xml里面写了。 //@Component 组件 public class User { public String name; //相当于<property name="name" value="荣哥"></property> @Value("rongge") public void setName(String name) { this.name = name; }
衍生的注解
@Component 有几个衍生注解,我们在web开发中,会按照mvc三层架构分层!
dao 【@Repository】
service 【@Service】
controller 【@Controller】
这四个注解功能都是一样的,都是代表将某个类注册到Spring容器中,装配Bean
自动装配置
- @Autowired 通过byType的方式实现,而且必须要求这个对象存在! - @Resource默认通过byname的方式实现,如果找不到名字,则通过byType实现!如果两个都找不到的情况下,就报错! - @Nullable 字段标记了这个注解,说明这个字段可以为null; - @Component 组件,放在类上,说明这个类被Spring管理了,就是bean!
作用域
@Component @Scope("prototype") public class User { public String name; //相当于<property name="name" value="荣哥"></property> @Value("rongge") public void setName(String name) { this.name = name; }
小结
xml 与 注解:
xml更加万能,适用于任何场合!维护简单方便
注解 不是自己类使用不了,维护相对复杂!
xml 与 注解最佳实践
xml用来管理bean
注解只负责完成属性的注入
我们在使用的过程中,只需要注意一个问题:必须让注解生效,就需要开启注解的支持
<!-- 指定要扫描的包,这个包下的注解就会生效--> <context:component-scan base-package="com.kuang"/>
我们现在完全不使用Spring的xml配置了,全权交给Java来做!
JavaConfig是Spring的一个子项目,在Spring4之后,它成为了一个核心功能!
实体类
//这里这个注解的意思,就是说明这个类被Spring接管了,注册到了容器中 @Component //这里注册了一个ser对象,User类中也注册了一个getUser对象,其实注册了两次 public class User { @Value("荣哥")//属性注入值 private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "User{" + "name='" + name + '\'' + '}'; } }
配置类
package com.kuang.config; import com.kuang.pojo.User; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; //这个也会被Spring容器托管,注册到容器中,因为它本来就是一个@Component, // @Configuration代表这是一个配置类,就和我们之前看的beans.xml @Configuration @ComponentScan("com.kuang")//如果不扫描包默认为单例模式,如果扫描了包可以通过dao的实体类小名来获取bean对象, // 就是说没加这个User类的@Component 创建了user对象就不起作用了。 @Import(KuangConfig.class) public class KuangConfig { //注册一个bean,就相当于我们之前写的一个bean标签, //这个方法的名字就相当于bean标签中的id属性 //这个方法的返回值就相当于bean标签中的class属性 @Bean public User getUser(){ return new User(); //就是返回要注入到bean的对象! } }
测试类
public class MyTest { public static void main(String[] args) { //如果完全使用了配置类方式去做,我们就只能通过 AnnotationConfig 上下文来获取容器,通过配置类的class对象加载! ApplicationContext context = new AnnotationConfigApplicationContext(KuangConfig.class); User getUser = (User) context.getBean("getUser"); User user = context.getBean("user", User.class); System.out.println(getUser.getName()); System.out.println(user.getName()); } } 输出两个荣哥
这种纯Java的配置方式,在SpringBoot中随处可见!