您好,登錄后才能下訂單哦!
本篇內容介紹了“Java動態(tài)腳本Groovy獲取Bean技巧是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
在Groovy
中不能使用@Autowired
(autowired是在spring啟動后注入的,此時還未加載groovy代碼,故無法注入)
它與 BeanPostProcessor
接口類似,可以對bean的定義(配置元數(shù)據(jù))進行處理;也就是spring ioc
運行BeanFactoryPostProcessor在容器實例化任何其他的bean之前讀取配置元數(shù)據(jù),并有可能修改它;如果業(yè)務需要,可以配置多個BeanFactoryPostProcessor的實現(xiàn)類,通過"order"控制執(zhí)行次序(要實現(xiàn)Ordered接口)。
import org.springframework.beans.BeansException; import org.springframework.beans.factory.config.BeanFactoryPostProcessor; import org.springframework.beans.factory.config.ConfigurableListableBeanFactory; import org.springframework.stereotype.Component; @Component public class SpringUtils implements BeanFactoryPostProcessor { /** Spring應用上下文環(huán)境 \*/ private static ConfigurableListableBeanFactory beanFactory; @Override public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException { SpringUtils.beanFactory = beanFactory; } @SuppressWarnings("unchecked") public static <T> T getBean(String name) throws BeansException { return (T) beanFactory.getBean(name); } public static <T> T getBean(Class<T> clz) throws BeansException { T result = (T) beanFactory.getBean(clz); return result; } }
package com.example.groovy.testgroovy.task; import groovy.lang.GroovyClassLoader; public class GroovyUtils { private final static ClassLoader classLoader = GroovyUtils.class.getClassLoader();//獲取當前類裝載器 //ClassLoader:就是類的裝載器,它使JVM可以動態(tài)的載入Java類,JVM并不需要知道從什么地方(本地文件、網(wǎng)絡等)載入Java類,這些都由ClassLoader完成。 public final static GroovyClassLoader groovyClassLoader = new GroovyClassLoader(classLoader); //GroovyClassLoader:負責在運行時編譯groovy源代碼為Class的工作,從而使Groovy實現(xiàn)了將groovy源代碼動態(tài)加載為Class的功能。 /** * . * 獲取實例化對象 * @param script groovy腳本內容 * @param <T> * @return * @throws IllegalAccessException * @throws InstantiationException */ public static <T> T instanceTaskGroovyScript(String script) throws IllegalAccessException, InstantiationException { Class taskClz = groovyClassLoader.parseClass(script); T instance = (T) taskClz.newInstance(); return instance; } }
@Slf4j @Component public class CallAnalysisGroovyTask { /** * . * 讀取腳本內容 * * @return */ public String getGroovy() { String context = ""; try { String path = "E:\\IDEAFile\\testgroovy\\src\\main\\resources\\groovy\\LoadBean.groovy"; context = FileUtils.readFileToString(new File(path));//將腳本內容轉為字符串 } catch (IOException e) { log.error("file is not found[{}]", e); } return context; } /** * . * 執(zhí)行groovy腳本 * * @param script */ public void execGroovy(String script) { try { Runnable runnable = GroovyUtils.instanceTaskGroovyScript(script);//獲取實例對象 runnable.run();//調用腳本方法 } catch (Exception t) { log.error("execGroovy file {} error", script); } } }
@Slf4j class LoadBean implements Runnable { /** * . * Groovy獲取Bean */ @Override void run() { log.info("Groovy開始執(zhí)行,當前類{}", this.getClass()) ScriptService service = SpringUtils.getBean(ScriptService.class) log.info("ApplicationContext獲取對象[{}]", service.class) List<Script> item = service.findAll()//執(zhí)行bean中數(shù)據(jù)查詢方法 for (Script s : item) { log.info("創(chuàng)建人:[{}],規(guī)則id:[{}],名稱:[{}]", s.getCreatePerson(), s.getRuleId(), s.getScriptName()) } log.info("Groovy結束執(zhí)行,當前類{}", this.getClass()) } }
@GetMapping("/loadBean") public void loadBean(){ String script = CallAnalysisGroovyTask.getGroovy(); //獲取腳本 CallAnalysisGroovyTask.execGroovy(script);//實例化腳本,執(zhí)行方法 log.info("數(shù)據(jù)查詢成功..."); }
腳本運行結果:
它是spring
繼BeanFactory
之外的另一個核心接口或容器,允許容器通過應用程序上下文環(huán)境創(chuàng)建、獲取、管理bean。為應用程序提供配置的中央接口。在應用程序運行時這是只讀的,但如果實現(xiàn)支持這一點,則可以重新加載。
@SpringBootApplication public class TestgroovyApplication { //獲取應用程序上下文環(huán)境 private static ApplicationContext applicationContext; public static void main(String[] args) { applicationContext = SpringApplication.run(TestgroovyApplication.class, args); }
/** * . * Groovy獲取Bean */ @Override void run() { log.info("Groovy開始執(zhí)行,當前類{}", this.getClass()) ScriptService service = TestgroovyApplication.applicationContext.getBean(ScriptService.class) log.info("ApplicationContext獲取對象[{}]", service.class) List<Script> item = service.findAll()//執(zhí)行bean中數(shù)據(jù)查詢方法 for (Script s : item) { log.info("創(chuàng)建人:[{}],規(guī)則id:[{}],名稱:[{}]", s.getCreatePerson(), s.getRuleId(), s.getScriptName()) } log.info("Groovy結束執(zhí)行,當前類{}", this.getClass()) }
腳本運行結果:
“Java動態(tài)腳本Groovy獲取Bean技巧是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。