Class HttpRequestHandlingController
java.lang.Object
org.springframework.integration.context.IntegrationObjectSupport
org.springframework.integration.endpoint.AbstractEndpoint
org.springframework.integration.gateway.MessagingGatewaySupport
org.springframework.integration.http.inbound.BaseHttpInboundEndpoint
org.springframework.integration.http.inbound.HttpRequestHandlingEndpointSupport
org.springframework.integration.http.inbound.HttpRequestHandlingController
- All Implemented Interfaces:
- Aware,- BeanFactoryAware,- BeanNameAware,- DisposableBean,- InitializingBean,- ApplicationContextAware,- Lifecycle,- Phased,- SmartLifecycle,- ExpressionCapable,- OrderlyShutdownCapable,- IntegrationPattern,- NamedComponent,- IntegrationInboundManagement,- IntegrationManagement,- ManageableLifecycle,- ManageableSmartLifecycle,- TrackableComponent,- Controller
public class HttpRequestHandlingController
extends HttpRequestHandlingEndpointSupport
implements Controller
Inbound HTTP endpoint that implements Spring's 
Controller interface to be used with a DispatcherServlet front
 controller.
 
 The viewName will be passed into the ModelAndView return value.
 
 This endpoint will have request/reply behavior by default. That can be overridden by passing false to
 the constructor. In the request/reply case, the core map will be passed to the view, and it will contain either the
 reply Message or payload depending on the value of BaseHttpInboundEndpoint.setExtractReplyPayload(boolean)
 (true by default, meaning just the payload).
 The corresponding key in the map is determined by the replyKey property (with a default of "reply").
- Since:
- 2.0
- Author:
- Mark Fisher, Gary Russell, Artem Bilan
- 
Nested Class SummaryNested classes/interfaces inherited from class org.springframework.integration.gateway.MessagingGatewaySupportMessagingGatewaySupport.ConvertingMessagingTemplateNested classes/interfaces inherited from interface org.springframework.integration.support.management.IntegrationManagementIntegrationManagement.ManagementOverrides
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe View model key for the error code.static final StringThe View model key for errors.static final StringThe View model key for reply.Fields inherited from class org.springframework.integration.http.inbound.BaseHttpInboundEndpointactiveCount, JAXB_PRESENT, NON_READABLE_BODY_HTTP_METHODS, ROME_TOOLS_PRESENTFields inherited from class org.springframework.integration.gateway.MessagingGatewaySupportmessagingTemplateFields inherited from class org.springframework.integration.endpoint.AbstractEndpointlifecycleCondition, lifecycleLockFields inherited from class org.springframework.integration.context.IntegrationObjectSupportEXPRESSION_PARSER, loggerFields inherited from interface org.springframework.integration.support.management.IntegrationManagementMETER_PREFIX, RECEIVE_COUNTER_NAME, SEND_TIMER_NAMEFields inherited from interface org.springframework.context.SmartLifecycleDEFAULT_PHASE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionfinal ModelAndViewhandleRequest(HttpServletRequest servletRequest, HttpServletResponse servletResponse) Handles the HTTP request by generating a Message and sending it to the request channel.protected voidonInit()Locates theMultipartResolverbean based on the default name defined by theDispatcherServlet.MULTIPART_RESOLVER_BEAN_NAMEconstant if available.voidsetErrorCode(String errorCode) The error code to use to signal an error in the message handling.voidsetErrorsKey(String errorsKey) The key used to exposeErrorsin the core, in the case that message handling fails.voidsetReplyKey(String replyKey) Specify the key to be used when adding the reply Message or payload to the core map (will be payload only unless the value ofBaseHttpInboundEndpoint.setExtractReplyPayload(boolean)isfalse).voidsetViewExpression(Expression viewExpression) Specifies a SpEL expression to evaluate in order to generate the view name.voidsetViewName(String viewName) Specify the view name.Methods inherited from class org.springframework.integration.http.inbound.HttpRequestHandlingEndpointSupportdoHandleRequest, extractRequestBody, getMessageConverters, prepareRequest, prepareRequestEntity, setMergeWithDefaultConverters, setMessageConverters, setMultipartResolver, setStatusCodeIfNeeded, setupResponseAndConvertReplyMethods inherited from class org.springframework.integration.http.inbound.BaseHttpInboundEndpointafterShutdown, beforeShutdown, createEvaluationContext, evaluateHttpStatus, getComponentType, getCrossOrigin, getExtractReplyPayload, getHeaderExpressions, getHeaderMapper, getIntegrationPatternType, getPayloadExpression, getRequestMapping, getRequestPayloadType, getStatusCodeExpression, getValidator, isExpectReply, isReadable, resolveHttpStatusFromHeaders, setCrossOrigin, setExtractReplyPayload, setHeaderExpressions, setHeaderMapper, setPayloadExpression, setRequestMapping, setRequestPayloadType, setRequestPayloadTypeClass, setStatusCodeExpression, setStatusCodeExpressionString, setValidator, validateMethods inherited from class org.springframework.integration.gateway.MessagingGatewaySupportbuildErrorMessage, buildSendTimer, destroy, doStart, doStop, getErrorChannel, getErrorMessageAttributes, getErrorMessageStrategy, getManagedName, getManagedType, getOverrides, getReplyChannel, getRequestChannel, isLoggingEnabled, isObserved, receive, receive, receiveMessage, receiveMessage, registerMetricsCaptor, registerObservationRegistry, registerReplyMessageCorrelatorIfNecessary, send, sendAndReceive, sendAndReceiveMessage, sendAndReceiveMessageReactive, sendTimer, setErrorChannel, setErrorChannelName, setErrorMessageStrategy, setErrorOnTimeout, setLoggingEnabled, setManagedName, setManagedType, setObservationConvention, setReceiverObservationConvention, setReplyChannel, setReplyChannelName, setReplyMapper, setReplyTimeout, setRequestChannel, setRequestChannelName, setRequestMapper, setRequestTimeout, setShouldTrackMethods inherited from class org.springframework.integration.endpoint.AbstractEndpointdoStop, getPhase, getRole, isActive, isAutoStartup, isRunning, setAutoStartup, setPhase, setRole, start, stop, stopMethods inherited from class org.springframework.integration.context.IntegrationObjectSupportafterPropertiesSet, extractTypeIfPossible, generateId, getApplicationContext, getApplicationContextId, getBeanDescription, getBeanFactory, getBeanName, getChannelResolver, getComponentName, getConversionService, getExpression, getIntegrationProperties, getMessageBuilderFactory, getTaskScheduler, isInitialized, setApplicationContext, setBeanFactory, setBeanName, setChannelResolver, setComponentName, setConversionService, setMessageBuilderFactory, setPrimaryExpression, setTaskScheduler, toStringMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.springframework.integration.support.management.IntegrationManagementgetThisAsMethods inherited from interface org.springframework.integration.support.context.NamedComponentgetBeanName, getComponentName
- 
Field Details- 
DEFAULT_ERROR_CODEThe View model key for the error code.- See Also:
 
- 
DEFAULT_REPLY_KEYThe View model key for reply.- See Also:
 
- 
DEFAULT_ERRORS_KEYThe View model key for errors.- See Also:
 
 
- 
- 
Constructor Details- 
HttpRequestHandlingControllerpublic HttpRequestHandlingController()
- 
HttpRequestHandlingControllerpublic HttpRequestHandlingController(boolean expectReply) 
 
- 
- 
Method Details- 
setViewNameSpecify the view name.- Parameters:
- viewName- The view name.
 
- 
setReplyKeySpecify the key to be used when adding the reply Message or payload to the core map (will be payload only unless the value ofBaseHttpInboundEndpoint.setExtractReplyPayload(boolean)isfalse). The default key is "reply".- Parameters:
- replyKey- The reply key.
 
- 
setErrorsKeyThe key used to exposeErrorsin the core, in the case that message handling fails. Defaults to "errors".- Parameters:
- errorsKey- The key value to set.
 
- 
setErrorCodeThe error code to use to signal an error in the message handling. In the case of an error this code will be provided in an object error to be optionally translated in the standard MVC way using aMessageSource. The default value isspring.integration.http.handler.error. Three arguments are provided: the exception, its message and its stack trace as a String.- Parameters:
- errorCode- The error code to set.
 
- 
setViewExpressionSpecifies a SpEL expression to evaluate in order to generate the view name. The EvaluationContext will be populated with the reply message as the root object,- Parameters:
- viewExpression- The view expression.
 
- 
onInitprotected void onInit()Description copied from class:HttpRequestHandlingEndpointSupportLocates theMultipartResolverbean based on the default name defined by theDispatcherServlet.MULTIPART_RESOLVER_BEAN_NAMEconstant if available. Sets up default converters if no converters set, orHttpRequestHandlingEndpointSupport.setMergeWithDefaultConverters(boolean)was called with true after the converters were set.- Overrides:
- onInitin class- HttpRequestHandlingEndpointSupport
 
- 
handleRequestpublic final ModelAndView handleRequest(HttpServletRequest servletRequest, HttpServletResponse servletResponse) Handles the HTTP request by generating a Message and sending it to the request channel. If this gateway's 'expectReply' property is true, it will also generate a response from the reply Message once received.- Specified by:
- handleRequestin interface- Controller
 
 
-