使用JavaConfig代替xml实现Spring配置操作

 更新时间:2021年09月27日 11:18:54   作者:想飞的鱼Stitch  
这篇文章主要介绍了使用JavaConfig代替xml实现Spring配置操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

JavaConfig代替xml实现Spring配置

简单实体类

package indi.stitch.pojo;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component
public class User {
    private String name;
    public String getName() {
        return name;
    }
    @Value("Stitch")
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                '}';
    }
}

@Component注解将实体类交给Spring容器托管,成为一个SpringBean组件

JavaConfig配置类

package indi.stitch.config;
import indi.stitch.pojo.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan("indi.stitch.pojo")
public class BeanConfig {
    @Bean
    public User getUser() {
        return new User();
    }
}
  • @Configuration注解代表这个类为Bean的配置类,相当于xml配置文件,本质上也是一个Component
  • @ComponentScan注解限定了配置类的扫描范围
  • @Bean表示被注册的Bean,相当于xml配置文件中的bean标签

测试类

import indi.stitch.config.BeanConfig;
import indi.stitch.pojo.User;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class MyTest {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(BeanConfig.class);
        User user = context.getBean("getUser", User.class);
        System.out.println(user.getName());
    }
}

使用JavaConfig的方式实现配置,需要使用AnnotationConfigApplicationContext类通过传入配置类的字节码对象获取Spring配置上下文,在此上下文中可以获取被@Bean标签标记的Bean对象,传入的参数为被@Bean标签标记的方法的方法名。

测试结果

在这里插入图片描述

脱离xml用JavaConfig配置Spring

情况一

配置类中类名添加 @Configuration 注解,同时提供一个方法返回一个Bean实例,且这个方法添加注解 @Bean ,就可以由Spring管理此对象

如下所示:

User.java( Bean )

public class User {
    private String name;
    public String getName() {
        return name;
    }
    @Value("Juyss") //注入name属性的值
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                '}';
    }
}

SpringConfig.java( Java配置类 )

@Configuration //表明此类为Spring配置类
public class SpringConfig {
    @Bean //返回一个实例,注册为一个Bean由Spring管理
    public User getUser(){
        return new User();
    }
}

ConfTest.java(测试类)

public class ConfTest {
    @Test
    public void Test(){
        ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
        User user = context.getBean("getUser", User.class); //第一个参数需与方法名一致
        System.out.println(user);
    }
}

测试类运行结果得到:

User{name='Juyss'}

情况二

配置类中类名上添加注解@Configuration表明为Spring配置类,添加注解@ComponentScan("ClassPath")表明扫描的包路径

然后在需要被Spring管理的Bean类名添加注解@Component

User.java ( Bean )

@Component //表明这个类注册为Bean组件
public class User {
    private String name;
    public String getName() {
        return name;
    }
    @Value("Juyss") //注入name属性的值
    public void setName(String name) {
        this.name = name;
    }
    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                '}';
    }
}

SpringConfig.java ( Java配置类 )

@Configuration //表明为Spring配置类
@ComponentScan("com.juyss.pojo") //扫描此包下的所有已注册的Bean
public class SpringConfig {
}
ConfTest.java ( 测试类 )
public class ConfTest {
    @Test
    public void Test(){
        ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
        User user = context.getBean("user", User.class); //第一个参数为类名首字母小写
        System.out.println(user);
    }
}

测试类运行结果得到:

User{name='Juyss'}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

最新评论