Spring Boot中Bean定義方調(diào)用方式解析
我們知道如果我們要在一個類使用spring提供的bean對象,我們需要把這個類注入到spring容器中,交給spring容器進行管理,但是在實際當中,我們往往會碰到在一個普通的Java類中,想直接使用spring提供的其他對象或者說有一些不需要交給spring管理,但是需要用到spring里的一些對象。如果這是spring框架的獨立應用程序,我們通過
ApplicationContextac=newFileSystemXmlApplicationContext("applicationContext.xml");
ac.getBean("beanId");
這樣的方式就可以很輕易的獲取我們所需要的對象。
但是往往我們所做的都是WebApplication,這時我們啟動spring容器是通過在web.xml文件中配置,這樣就不適合使用上面的方式在普通類去獲取對象了,因為這樣做就相當于加載了兩次spring容器,而我們想是否可以通過在啟動web服務器的時候,就把Application放在某一個類中,我們通過這個類在獲取,這樣就可以在普通類獲取springbean對象了,讓我們接著往下看
下面介紹在SpringBoot中是如何使用的
1.在Spring Boot可以掃描的包下
寫的工具類為SpringUtil,實現(xiàn)ApplicationContextAware接口,并加入Component注解,讓spring掃描到該bean
springutil:
package me.shijunjie.util;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;
@Component
public class SpringUtil implements ApplicationContextAware {
private static ApplicationContext applicationContext;
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
if(SpringUtil.applicationContext == null) {
SpringUtil.applicationContext = applicationContext;
}
System.out.println("---------------------------------------------------------------------");
System.out.println("---------------------------------------------------------------------");
System.out.println("---------------me.shijunjie.util.SpringUtil------------------------------------------------------");
System.out.println("========ApplicationContext配置成功,在普通類可以通過調(diào)用SpringUtils.getAppContext()獲取applicationContext對象,applicationContext="+SpringUtil.applicationContext+"========");
System.out.println("---------------------------------------------------------------------");
}
//獲取applicationContext
public static ApplicationContext getApplicationContext() {
return applicationContext;
}
//通過name獲取 Bean.
public static Object getBean(String name){
return getApplicationContext().getBean(name);
}
//通過class獲取Bean.
public static <T> T getBean(Class<T> clazz){
return getApplicationContext().getBean(clazz);
}
//通過name,以及Clazz返回指定的Bean
public static <T> T getBean(String name,Class<T> clazz){
return getApplicationContext().getBean(name, clazz);
}
}
為了測試,我們再啟動的時候先通過代碼方式給spring容器中注入一個bean,入下所示
package me.shijunjie.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import me.shijunjie.entity.Demo2;
@Configuration
public class BeanConfig {
@Bean(name="testDemo")
public Demo2 generateDemo() {
Demo2 demo = new Demo2();
demo.setId(12345);
demo.setName("test");
return demo;
}
}
然后我們編寫測試controller,并從剛才寫的springutil中獲取這個bean
package me.shijunjie.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import me.shijunjie.util.SpringUtil;
@RestController
@RequestMapping("/application")
public class TestApplicationController {
@RequestMapping("/test1")
public Object testSpringUtil1() {
return SpringUtil.getBean("testDemo");
}
}
測試
啟動web應用,打開瀏覽器輸入http://localhost:8080/application/test1,測試成功

2不在Spring Boot的掃描包下
這種情況處理起來也很簡單,先編寫SpringUtil類,同樣需要實現(xiàn)接口:ApplicationContextAware,具體編碼如下:
package me.shijunjie.util;
import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
public class SpringUtil2 implements ApplicationContextAware {
private static ApplicationContext applicationContext;
@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
if(SpringUtil2.applicationContext == null) {
SpringUtil2.applicationContext = applicationContext;
}
System.out.println("---------------------------------------------------------------------");
System.out.println("---------------------------------------------------------------------");
System.out.println("---------------me.shijunjie.util.SpringUtil------------------------------------------------------");
System.out.println("========ApplicationContext配置成功,在普通類可以通過調(diào)用SpringUtils.getAppContext()獲取applicationContext對象,applicationContext="+SpringUtil2.applicationContext+"========");
System.out.println("---------------------------------------------------------------------");
}
//獲取applicationContext
public static ApplicationContext getApplicationContext() {
return applicationContext;
}
//通過name獲取 Bean.
public static Object getBean(String name){
return getApplicationContext().getBean(name);
}
//通過class獲取Bean.
public static <T> T getBean(Class<T> clazz){
return getApplicationContext().getBean(clazz);
}
//通過name,以及Clazz返回指定的Bean
public static <T> T getBean(String name,Class<T> clazz){
return getApplicationContext().getBean(name, clazz);
}
}
使用@Bean注解,在App.java類中將SpringUtil注解進
package me.shijunjie.controller;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.web.SpringBootServletInitializer;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.scheduling.annotation.EnableScheduling;
import me.shijunjie.util.SpringUtil2;
@ComponentScan(basePackages={"me.shijunjie"}) // 掃描該包路徑下的所有spring組件
/*@EnableJpaRepositories("me.shijunjie.dao") // JPA掃描該包路徑下的Repositorie
*//*@EntityScan("me.shijunjie.entity") // 掃描實體類
*/@SpringBootApplication
@EnableScheduling
public class App extends SpringBootServletInitializer{
@Bean
public SpringUtil2 getSpringUtil2() {
return new SpringUtil2();
}
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
測試(使用熱部署的需要重啟服務器)
啟動web應用,打開瀏覽器輸入http://localhost:8080/application/test2,測試成功

除此以外,也可以在App.java中使用@Import進行導入。
package me.shijunjie.controller;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.web.SpringBootServletInitializer;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Import;
import org.springframework.scheduling.annotation.EnableScheduling;
import me.shijunjie.util.SpringUtil2;
@ComponentScan(basePackages={"me.shijunjie"}) // 掃描該包路徑下的所有spring組件
/*@EnableJpaRepositories("me.shijunjie.dao") // JPA掃描該包路徑下的Repositorie
*//*@EntityScan("me.shijunjie.entity") // 掃描實體類
*/@SpringBootApplication
@EnableScheduling
@Import(SpringUtil2.class)
public class App extends SpringBootServletInitializer{
/*@Bean
public SpringUtil2 getSpringUtil2() {
return new SpringUtil2();
}*/
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
跑出結(jié)果和上面相同
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot使用SOFA-Lookout監(jiān)控的方法
本文介紹SpringBoot使用螞蟻金服SOFA-Lookout配合Prometheus進行監(jiān)控,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03
MyBatis-Plus UpdateWrapper 使用常見陷阱和解決方案
MyBatis-Plus是Mybatis的一個增強,簡化了Mybatis的開發(fā)過程,不僅保持了Mybatis原有的功能,而且在無代碼侵略下增加了許多的增強的功能,提供了豐富的CRUD操作,單表的CRUD操作無需編寫SQL語句,本文介紹的是UpdateWrapper的常見陷阱和對應的解決方案,感興趣的朋友一起看看吧2024-08-08
Java JDK動態(tài)代理(AOP)用法及實現(xiàn)原理詳解
在本篇文章了小編給大家整理的是一篇關于Java JDK動態(tài)代理(AOP)用法及實現(xiàn)原理詳解內(nèi)容,有需要的朋友們可以參考學習下。2020-10-10
基于Java Socket實現(xiàn)一個簡易在線聊天功能(一)
這篇文章主要給大家介紹基于Java Socket實現(xiàn)一個簡易在線聊天功能(一),分為客戶端和服務端兩段代碼,非常具有參考價值,感興趣的朋友一起學習吧2016-05-05
java calendar 日期實現(xiàn)不斷加一天的代碼
這篇文章主要介紹了java calendar 日期實現(xiàn)不斷加一天的代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10

