<menu id="guoca"></menu>
<nav id="guoca"></nav><xmp id="guoca">
  • <xmp id="guoca">
  • <nav id="guoca"><code id="guoca"></code></nav>
  • <nav id="guoca"><code id="guoca"></code></nav>

    Spring中獲取bean的八種方式,你get了幾種?

    VSole2022-12-12 13:49:02

    1、在初始化時保存ApplicationContext對象

    適用于Spring框架的獨立應用程序,須要程序通過配置文件初始化Spring。

    applicationContext.xml配置:

    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xmlns:p="http://www.springframework.org/schema/p"
           xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    <bean id="test" class="com.sxtx.bean.Test">
    bean>
    beans>
    

    代碼:

    @Test
    public void test() {
        ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");
        //ApplicationContext applicationContext = new FileSystemXmlApplicationContext("applicationContext.xml"); 
        Test test= (Test) applicationContext.getBean("test");
        System.out.println(test);
    }
    

    2、通過Spring提供的工具類獲取ApplicationContext對象

    適合于Spring框架的B/S系統,通過ServletContext對象獲取ApplicationContext對象。然后在通過它獲取須要的類實例。以下兩個工具方式的差別是,前者在獲取失敗時拋出異常。后者返回null。

    ApplicationContext ac1 = WebApplicationContextUtils.getRequiredWebApplicationContext(ServletContext sc); 
    ApplicationContext ac2 = WebApplicationContextUtils.getWebApplicationContext(ServletContext sc); 
    ac1.getBean("beanId"); 
    ac2.getBean("beanId");  
    

    3、實現接口ApplicationContextAware(推薦)

    實現該接口的setApplicationContext(ApplicationContext context)方法,并保存ApplicationContext 對象。Spring初始化時,掃描到該類,就會通過該方法將ApplicationContext對象注入。然后在代碼中就可以獲取spring容器bean了。

    例如:

    User bean = SpringUtils.getBean(“user”);
    @Component
    public class SpringUtils implements ApplicationContextAware {
     
        private static ApplicationContext applicationContext;
        @Override
        public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
            SpringUtils.applicationContext = applicationContext;
        }
     
        public static  T getBean(String beanName) {
            if(applicationContext.containsBean(beanName)){
                return (T) applicationContext.getBean(beanName);
            }else{
                return null;
            }
        }
     
        public static  Map getBeansOfType(Class baseType){
            return applicationContext.getBeansOfType(baseType);
        }
    }
    

    4、繼承自抽象類ApplicationObjectSupport

    調用父類的getApplicationContext()方法,獲取Spring容器對象。

    @Service
    public class SpringContextHelper extends ApplicationObjectSupport {
        public Object getBean(String beanName) {
            return getApplicationContext().getBean(beanName);
        }
    }
    

    5、繼承自抽象類WebApplicationObjectSupport

    調用getWebApplicationContext()獲取WebApplicationContext

    @Service
    public class SpringContextHelper extends WebApplicationObjectSupport {
        public Object getBean(String beanName) {
            return getApplicationContext().getBean(beanName);
        }
    }
    

    6、使用BeanFactory直接獲取(不推薦)

    使用BeanFactory從工廠中直接獲取Bean實例,但是XmlBeanFactory類已經廢棄,因此不建議使用。

    @Test
    public void test() {
        BeanFactory beanFactory = new XmlBeanFactory(new ClassPathResource("applicationContext.xml"));
        Test test= (Test) beanFactory.getBean("test");
        System.out.println(test);
    }
    

    7、使用ContextLoader提供的getCurrentWebApplicationContext方法

    @Test
    public void test() {
        MockServletContext sc = new MockServletContext("");
        sc.addInitParameter(ContextLoader.CONFIG_LOCATION_PARAM, "/applicationContext.xml");
        ServletContextListener listener = new ContextLoaderListener();
        ServletContextEvent event = new ServletContextEvent(sc);
        listener.contextInitialized(event);
        
        WebApplicationContext wac = ContextLoader.getCurrentWebApplicationContext();
        Test test= (Test) wac.getBean("test");
        System.out.println(test);
    }
    

    8、實現接口BeanFactoryPostProcessor

    spring工具類 方便在非spring管理環境中獲取bean

    @Component
    public final class SpringUtilsS implements BeanFactoryPostProcessor
    {
        /** Spring應用上下文環境 */
        private static ConfigurableListableBeanFactory beanFactory;
        @Override
        public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException
        {
            SpringUtilsS.beanFactory = beanFactory;
        }
        /**
         * 獲取對象
         *
         * @param name
         * @return Object 一個以所給名字注冊的bean的實例
         * @throws BeansException
         *
         */
        @SuppressWarnings("unchecked")
        public static  T getBean(String name) throws BeansException
        {
            return (T) beanFactory.getBean(name);
        }
        /**
         * 獲取類型為requiredType的對象
         *
         * @param clz
         * @return
         * @throws BeansException
         *
         */
        public static  T getBean(Class clz) throws BeansException
        {
            T result = (T) beanFactory.getBean(clz);
            return result;
        }
        /**
         * 如果BeanFactory包含一個與所給名稱匹配的bean定義,則返回true
         *
         * @param name
         * @return boolean
         */
        public static boolean containsBean(String name)
        {
            return beanFactory.containsBean(name);
        }
        /**
         * 判斷以給定名字注冊的bean定義是一個singleton還是一個prototype。 如果與給定名字相應的bean定義沒有被找到,將會拋出一個異常(NoSuchBeanDefinitionException)
         *
         * @param name
         * @return boolean
         * @throws NoSuchBeanDefinitionException
         *
         */
        public static boolean isSingleton(String name) throws NoSuchBeanDefinitionException
        {
            return beanFactory.isSingleton(name);
        }
        /**
         * @param name
         * @return Class 注冊對象的類型
         * @throws NoSuchBeanDefinitionException
         *
         */
        public static Class getType(String name) throws NoSuchBeanDefinitionException
        {
            return beanFactory.getType(name);
        }
        /**
         * 如果給定的bean名字在bean定義中有別名,則返回這些別名
         *
         * @param name
         * @return
         * @throws NoSuchBeanDefinitionException
         *
         */
        public static String[] getAliases(String name) throws NoSuchBeanDefinitionException
        {
            return beanFactory.getAliases(name);
        }
        /**
         * 獲取aop代理對象
         * 
         * @param invoker
         * @return
         */
        @SuppressWarnings("unchecked")
        public static  T getAopProxy(T invoker)
        {
            return (T) AopContext.currentProxy();
        }
    }
    

    擴展

    BeanFactoryApplicationContext是Spring的兩大核心接口,都可以當做Spring的容器。其中ApplicationContextBeanFactory的子接口。

    BeanFactory

    (1)、是Spring里面最底層的接口(最原始的接口),包含了各種Bean的定義,讀取bean配置文檔,管理bean的加載、實例化,控制bean的生命周期,維護bean之間的依賴關系。

    (2)、采用的是延遲加載形式來注入Bean的,即只有在使用到某個Bean時(調用getBean()),才對該Bean進行加載實例化。這樣,我們就不能發現一些存在的Spring的配置問題。如果Bean的某一個屬性沒有注入,BeanFacotry加載后,直至第一次使用調用getBean方法才會拋出異常。

    (3)BeanFactory通常以編程的方式被創建。

    (4)BeanFactoryApplicationContext都支持BeanPostProcessorBeanFactoryPostProcessor的使用,但兩者之間的區別是:BeanFactory需要手動注冊,而ApplicationContext則是自動注冊。

    (5) 占用內存小。

    ApplicationContext

    1、ApplicationContext接口作為BeanFactory的派生,除了提供BeanFactory所具有的功能外,還提供了更完整的框架功能:

    • 繼承MessageSource,因此支持國際化。
    • 統一的資源文件訪問方式。
    • 提供在監聽器中注冊bean的事件。
    • 同時加載多個配置文件。
    • 載入多個(有繼承關系)上下文 ,使得每一個上下文都專注于一個特定的層次,比如應用的web層。

    2、ApplicationContext,它是在容器啟動時,一次性創建了所有的Bean。這樣,在容器啟動時,我們就可以發現Spring中存在的配置錯誤,這樣有利于檢查所依賴屬性是否注入。ApplicationContext啟動后預載入所有的單實例Bean,通過預載入單實例bean ,確保當你需要的時候,你就不用等待,因為它們已經創建好了。

    3、ApplicationContext 占用內存空間大,當程序的配置bean特別多時,程序啟動慢。

    4、ApplicationContext 能以編程式方式創建,還能能以聲明的方式創建,如使用ContextLoader

    testbean
    本作品采用《CC 協議》,轉載必須注明作者和本文鏈接
    以下兩個工具方式的差別是,前者在獲取失敗時拋出異常。然后在代碼中就可以獲取spring容器bean了。
    部分getshell漏洞匯總
    2022-07-20 10:12:45
    即可未授權訪問console后臺,但是權限比較低備注:此處會出現個問題,在復現的環境中直接拼接
    Spring框架是一個開放源代碼的J2EE應用程序框架,是針對bean的生命周期進行管理的輕量級容器。Spring可以單獨應用于構筑應用程序,也可以和Struts、Webwork、Tapestry等眾多Web框架組合使用,并且可以與 Swing等桌面應用程序AP組合。 Spring框架主要由七部分組成,分別是 Spring Core、 Spring AOP、 Spring ORM、 Spring
    所以,這就要求Spring事務能支持上面各種場景,這就是Spring事務傳播機制的由來。
    介紹實戰中由于各種情況,可能會對反序列化Payload的長度有所限制,因此研究反序列化Payload縮小技術是有意義且必要的本文以CommonsBeanutils1鏈為示例,
    雖說是 Spring 框架漏洞,但以下包含并不僅 Spring Framework,Spring Boot,還有 Spring Cloud,Spring Data,Spring Security 等。
    雖說是 Spring 框架漏洞,但以下包含并不僅 Spring Framework,Spring Boot,還有 Spring Cloud,Spring Data,Spring Security 等。 CVE-2010-1622 Spring Framework class.classLoader 類遠程代碼執行 影響版本:SpringSource Spring Framework 3.0.0
    S2-009是S2-003與S2-005的補丁繞過,當時的補丁是增加了正則以及相關的限制,主要的防御還是正則。
    VSole
    網絡安全專家
      亚洲 欧美 自拍 唯美 另类