All Downloads are FREE. Search and download functionalities are using the official Maven repository.

infra.beans.factory.config.MethodInvokingBean Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017 - 2024 the original author or authors.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see [https://www.gnu.org/licenses/]
 */

package infra.beans.factory.config;

import java.lang.reflect.InvocationTargetException;

import infra.beans.TypeConverter;
import infra.beans.factory.BeanClassLoaderAware;
import infra.beans.factory.BeanFactory;
import infra.beans.factory.BeanFactoryAware;
import infra.beans.factory.InitializingBean;
import infra.beans.support.ArgumentConvertingMethodInvoker;
import infra.lang.Nullable;
import infra.util.ClassUtils;
import infra.util.ReflectiveMethodInvoker;

/**
 * Simple method invoker bean: just invoking a target method, not expecting a result
 * to expose to the container (in contrast to {@link MethodInvokingFactoryBean}).
 *
 * 

This invoker supports any kind of target method. A static method may be specified * by setting the {@link #setTargetMethod targetMethod} property to a String representing * the static method name, with {@link #setTargetClass targetClass} specifying the Class * that the static method is defined on. Alternatively, a target instance method may be * specified, by setting the {@link #setTargetObject targetObject} property as the target * object, and the {@link #setTargetMethod targetMethod} property as the name of the * method to call on that target object. Arguments for the method invocation may be * specified by setting the {@link #setArguments arguments} property. * *

This class depends on {@link #afterPropertiesSet()} being called once * all properties have been set, as per the InitializingBean contract. * *

An example (in an XML based bean factory definition) of a bean definition * which uses this class to call a static initialization method: * *

 * <bean id="myObject" class="infra.beans.factory.config.MethodInvokingBean">
 *   <property name="staticMethod" value="com.whatever.MyClass.init"/>
 * </bean>
* *

An example of calling an instance method to start some server bean: * *

 * <bean id="myStarter" class="infra.beans.factory.config.MethodInvokingBean">
 *   <property name="targetObject" ref="myServer"/>
 *   <property name="targetMethod" value="start"/>
 * </bean>
* * @author Juergen Hoeller * @author Harry Yang * @see MethodInvokingFactoryBean * @see ReflectiveMethodInvoker * @since 4.0 2022/2/18 11:13 */ public class MethodInvokingBean extends ArgumentConvertingMethodInvoker implements BeanClassLoaderAware, BeanFactoryAware, InitializingBean { @Nullable private ClassLoader beanClassLoader = ClassUtils.getDefaultClassLoader(); @Nullable private ConfigurableBeanFactory beanFactory; @Override public void setBeanClassLoader(ClassLoader classLoader) { this.beanClassLoader = classLoader; } @Override protected Class resolveClassName(String className) throws ClassNotFoundException { return ClassUtils.forName(className, this.beanClassLoader); } @Override public void setBeanFactory(BeanFactory beanFactory) { if (beanFactory instanceof ConfigurableBeanFactory) { this.beanFactory = (ConfigurableBeanFactory) beanFactory; } } /** * Obtain the TypeConverter from the BeanFactory that this bean runs in, * if possible. * * @see ConfigurableBeanFactory#getTypeConverter() */ @Override protected TypeConverter getDefaultTypeConverter() { if (this.beanFactory != null) { return this.beanFactory.getTypeConverter(); } else { return super.getDefaultTypeConverter(); } } @Override public void afterPropertiesSet() throws Exception { prepare(); invokeWithTargetException(); } /** * Perform the invocation and convert InvocationTargetException * into the underlying target exception. */ @Nullable protected Object invokeWithTargetException() throws Exception { try { return invoke(); } catch (InvocationTargetException ex) { if (ex.getTargetException() instanceof Exception) { throw (Exception) ex.getTargetException(); } if (ex.getTargetException() instanceof Error) { throw (Error) ex.getTargetException(); } throw ex; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy