JavaConfig代替xml實現Spring配置
簡單實體類
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
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配置類
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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標簽
測試類
1
2
3
4
5
6
7
8
9
10
11
|
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 )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
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配置類 )
1
2
3
4
5
6
7
|
@Configuration //表明此類為Spring配置類 public class SpringConfig { @Bean //返回一個實例,注冊為一個Bean由Spring管理 public User getUser(){ return new User(); } } |
ConfTest.java(測試類)
1
2
3
4
5
6
7
8
|
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 )
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
@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配置類 )
1
2
3
4
5
6
7
8
9
10
11
12
13
|
@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'}
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/qq_39209361/article/details/115362894