Package org.springframework.web.method
Class HandlerMethod
java.lang.Object
org.springframework.web.method.HandlerMethod
- Direct Known Subclasses:
- InvocableHandlerMethod,- InvocableHandlerMethod,- SyncInvocableHandlerMethod
Encapsulates information about a handler method consisting of a
 method and a bean.
 Provides convenient access to method parameters, the method return value,
 method annotations, etc.
 
The class may be created with a bean instance or with a bean name
 (e.g. lazy-init bean, prototype bean). Use createWithResolvedBean()
 to obtain a HandlerMethod instance with a bean instance resolved
 through the associated BeanFactory.
- Since:
- 3.1
- Author:
- Arjen Poutsma, Rossen Stoyanchev, Juergen Hoeller, Sam Brannen
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected classA MethodParameter with HandlerMethod-specific behavior.
- 
Field SummaryFields
- 
Constructor SummaryConstructorsModifierConstructorDescriptionHandlerMethod(Object bean, Method method) Create an instance from a bean instance and a method.protectedHandlerMethod(Object bean, Method method, MessageSource messageSource) Variant ofHandlerMethod(Object, Method)that also accepts aMessageSourcefor use from sub-classes.HandlerMethod(Object bean, String methodName, Class<?>... parameterTypes) Create an instance from a bean instance, method name, and parameter types.HandlerMethod(String beanName, BeanFactory beanFactory, Method method) Create an instance from a bean name, a method, and aBeanFactory.HandlerMethod(String beanName, BeanFactory beanFactory, MessageSource messageSource, Method method) Variant ofHandlerMethod(String, BeanFactory, Method)that also accepts aMessageSource.protectedHandlerMethod(HandlerMethod handlerMethod) Copy constructor for use in subclasses.
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidassertTargetBean(Method method, Object targetBean, Object[] args) Assert that the target bean class is an instance of the class where the given method is declared.If the provided instance contains a bean name rather than an object instance, the bean name is resolved before aHandlerMethodis created and returned.booleanprotected static ObjectfindProvidedArgument(MethodParameter parameter, Object... providedArgs) protected static StringformatArgumentError(MethodParameter param, String message) protected StringformatInvokeError(String text, Object[] args) getBean()Return the bean for this handler method.Class<?>This method returns the type of the handler for this handler method.protected MethodIf the bean method is a bridge method, this method returns the bridged (user-defined) method.Return the method for this handler method.<A extends Annotation>
 AgetMethodAnnotation(Class<A> annotationType) Return a single annotation on the underlying method traversing its super methods if no annotation can be found on the given method itself.Return the method parameters for this handler method.Return the HandlerMethod from which this HandlerMethod instance was resolved viacreateWithResolvedBean().protected HttpStatusReturn the specified response status, if any.protected StringReturn the associated response status reason, if any.Return the HandlerMethod return type.getReturnValueType(Object returnValue) Return the actual return value type.Return a short representation of this handler method for log message purposes.inthashCode()<A extends Annotation>
 booleanhasMethodAnnotation(Class<A> annotationType) Return whether the parameter is declared with the given annotation type.booleanisVoid()Returntrueif the method return type is void,falseotherwise.toString()
- 
Field Details- 
loggerLogger that is available to subclasses.
 
- 
- 
Constructor Details- 
HandlerMethodCreate an instance from a bean instance and a method.
- 
HandlerMethodVariant ofHandlerMethod(Object, Method)that also accepts aMessageSourcefor use from sub-classes.- Since:
- 5.3.10
 
- 
HandlerMethodpublic HandlerMethod(Object bean, String methodName, Class<?>... parameterTypes) throws NoSuchMethodException Create an instance from a bean instance, method name, and parameter types.- Throws:
- NoSuchMethodException- when the method cannot be found
 
- 
HandlerMethodCreate an instance from a bean name, a method, and aBeanFactory. The methodcreateWithResolvedBean()may be used later to re-create theHandlerMethodwith an initialized bean.
- 
HandlerMethodpublic HandlerMethod(String beanName, BeanFactory beanFactory, @Nullable MessageSource messageSource, Method method) Variant ofHandlerMethod(String, BeanFactory, Method)that also accepts aMessageSource.
- 
HandlerMethodCopy constructor for use in subclasses.
 
- 
- 
Method Details- 
getBeanReturn the bean for this handler method.
- 
getMethodReturn the method for this handler method.
- 
getBeanTypeThis method returns the type of the handler for this handler method.Note that if the bean type is a CGLIB-generated class, the original user-defined class is returned. 
- 
getBridgedMethodIf the bean method is a bridge method, this method returns the bridged (user-defined) method. Otherwise it returns the same method asgetMethod().
- 
getMethodParametersReturn the method parameters for this handler method.
- 
getResponseStatusReturn the specified response status, if any.- Since:
- 4.3.8
- See Also:
 
- 
getResponseStatusReasonReturn the associated response status reason, if any.- Since:
- 4.3.8
- See Also:
 
- 
getReturnTypeReturn the HandlerMethod return type.
- 
getReturnValueTypeReturn the actual return value type.
- 
isVoidpublic boolean isVoid()Returntrueif the method return type is void,falseotherwise.
- 
getMethodAnnotationReturn a single annotation on the underlying method traversing its super methods if no annotation can be found on the given method itself.Also supports merged composed annotations with attribute overrides as of Spring Framework 4.2.2. - Parameters:
- annotationType- the type of annotation to introspect the method for
- Returns:
- the annotation, or nullif none found
- See Also:
 
- 
hasMethodAnnotationReturn whether the parameter is declared with the given annotation type.- Parameters:
- annotationType- the annotation type to look for
- Since:
- 4.3
- See Also:
 
- 
getResolvedFromHandlerMethodReturn the HandlerMethod from which this HandlerMethod instance was resolved viacreateWithResolvedBean().
- 
createWithResolvedBeanIf the provided instance contains a bean name rather than an object instance, the bean name is resolved before aHandlerMethodis created and returned.
- 
getShortLogMessageReturn a short representation of this handler method for log message purposes.- Since:
- 4.3
 
- 
equals
- 
hashCodepublic int hashCode()
- 
toString
- 
findProvidedArgument@Nullable protected static Object findProvidedArgument(MethodParameter parameter, @Nullable Object... providedArgs) 
- 
formatArgumentError
- 
assertTargetBeanAssert that the target bean class is an instance of the class where the given method is declared. In some cases the actual controller instance at request- processing time may be a JDK dynamic proxy (lazy initialization, prototype beans, and others).@Controller's that require proxying should prefer class-based proxy mechanisms.
- 
formatInvokeError
 
-