我们现在要完全不适用Spring的xml配置了,全权交给Java来做!
JavaConfig 是Spring的一个子项目,在spring4之后,他成为了一个核心功能!
实体类pojo
这里这个注解的意思,就是说明这个类被Spring接管了,注册到了容器中
package cn.edu.jxust.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("睡意昏沉") //属性注入值
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{" +
"name='" + name + '\'' +
'}';
}
}
配置类config
这个也会Spring容器托管,注册到容器中,因为他本来就是一个@Component @Configuration代表这是一个配置类,就和我们之前看的beans.xml
package cn.edu.jxust.config;
import cn.edu.jxust.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("cn.edu.jxust.pojo")
public class JxustConfig {
//注册一个bean,就相当于我们之前写的一个bean标签
//这个方法的名字,就相当于bean标签中的id属性
//这个方法的返回值,就相当于bean标签中的class属性
@Bean
public User getUser(){
return new User(); //就是返回要注入到bean的对象!
}
}
测试类Test
如果完全使用了配置类方式去做,我们就只能通过AnnotationConfig上下文来获取容器,通过配置类的class对象加载!
import cn.edu.jxust.config.JxustConfig;
import cn.edu.jxust.pojo.User;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class Test {
public static void main(String[] args) {
//如果完全使用了配置类方式去做,我们就只能通过AnnotationConfig上下文来获取容器,
//通过配置类的class对象加载!
ApplicationContext context = new AnnotationConfigApplicationContext(JxustConfig.class);
User getUser = (User) context.getBean("user");//getUser
System.out.println(getUser.getName());
}
}
这种纯Java的配置方式,在SpringBoot中随处可见!