User实体类
package com.li.dao;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
//@Component的意思,就是说明这个类被Spring接管了,注册到了容器中
@Component
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 + '\'' +
'}';
}
}
配置类1
package com.li.config;
import com.li.dao.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
//这个也会被Spring容器托管,注册到容器中,因为它本来就是一个@Component
//@Configuration代表这是一个配置类,就和我们之前看到的bean.xml一样的,也就说明了xml能做的它也可以做
@Configuration
@Import(Myconfig2.class)//引入另一个配置类
public class Myconfig {
//@Bean:注册一个bean,就相当于我们之前写的一个bean标签
//这个方法的名字,相当于bean标签中的id属性
//这个方法的返回值,相当于bean标签中的class属性
@Bean
public User getUser(){
return new User();//就是返回要注入到bean的对象!
}
}
假设另一个配置类2,方便测试配置类1引入配置类2
package com.li.config;
import org.springframework.context.annotation.Configuration;
//测试配置类2
@Configuration
public class Myconfig2 {
}
测试类:注意这里和xml自动自动装配不一样的地方是:通过 AnnotationConfig 上下文来获取容器,通过配置类的class对象加载
package com.li.dao;
import com.li.config.Myconfig;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class TestGo {
@Test
public void test1(){
// 如果完全使用了配置了方式去做,我们就只能通过 AnnotationConfig 上下文来获取容器,通过配置类的class对象加载
ApplicationContext context = new AnnotationConfigApplicationContext(Myconfig.class);
User user = (User)context.getBean("getUser");//getBean 的参数是配置类中的方法名
System.out.println(user.getName());
}
}