们现在完全不适用Spring的xml配置了,全权交给java来做
JavaConfig是Spring的一个子项目,在Spring4之后,它成为了一个核心功能
9.1、实体类
package com.lalala.pojo; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; // 这个注解的意思,就是说明这个类被Spring接管了,注册到了容器中 @Component public class User { private String name; public String getName() { return name; } @Value("Bear")//属性注入值 public void setName(String name) { this.name = name; } @Override public String toString() { return "User{" + "name='" + name + '\'' + '}'; } }
9.2、配置文件
package com.lalala.config; import com.lalala.pojo.User; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; // 这个也会被Spring容器托管,注册到容器中,因为他本来就是一个@component,@Configuration代表这是一个配置类,就和我们之前看的beans.xml一样 @Configuration //@ComponentScan("com.lalala.pojo") public class MyConfig { //注册一个bean,就相当于我们之前写的一个bean标签 //这个方法的名字,就相当于bean标签中的id属性 //这个方法的返回值,就相当于bean标签中的class属性 @Bean public User getUser() { return new User(); //就是返回要注入到bean的对象 } }
9.3、测试类
import com.lalala.config.MyConfig; import com.lalala.pojo.User; import org.junit.Test; import org.springframework.context.ApplicationContext; import org.springframework.context.annotation.AnnotationConfigApplicationContext; public class MyTest { @Test public void test01() { // 如果完全使用了配置类方式去做,我们就只能通过 AnnotationConfig 上下文来获取容器,通过配置类的class对象加载 ApplicationContext context = new AnnotationConfigApplicationContext(MyConfig.class); User getUser = (User) context.getBean("getUser"); System.out.println(getUser.getName()); } }