Class DefaultErrorWebExceptionHandler
- All Implemented Interfaces:
org.springframework.beans.factory.InitializingBean,org.springframework.boot.web.reactive.error.ErrorWebExceptionHandler,org.springframework.web.server.WebExceptionHandler
WebExceptionHandler, rendering
ErrorAttributes.
More specific errors can be handled either using Spring WebFlux abstractions (e.g.
@ExceptionHandler with the annotation model) or by adding
RouterFunction to the chain.
This implementation will render error as HTML views if the client explicitly supports
that media type. It attempts to resolve error views using well known conventions. Will
search for templates and static assets under '/error' using the
status code and the status series.
For example, an HTTP 404 will search (in the specific order):
'/<templates>/error/404.<ext>''/<static>/error/404.html''/<templates>/error/4xx.<ext>''/<static>/error/4xx.html''/<templates>/error/error''/<static>/error/error.html'
If none found, a default "Whitelabel Error" HTML view will be rendered.
If the client doesn't support HTML, the error information will be rendered as a JSON payload.
- Since:
- 2.0.0
-
Constructor Summary
ConstructorsConstructorDescriptionDefaultErrorWebExceptionHandler(org.springframework.boot.web.reactive.error.ErrorAttributes errorAttributes, WebProperties.Resources resources, ErrorProperties errorProperties, org.springframework.context.ApplicationContext applicationContext) Create a newDefaultErrorWebExceptionHandlerinstance. -
Method Summary
Modifier and TypeMethodDescriptionprotected org.springframework.web.reactive.function.server.RequestPredicatePredicate that checks whether the current request explicitly support"text/html"media type.protected org.springframework.boot.web.error.ErrorAttributeOptionsgetErrorAttributeOptions(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType mediaType) protected intgetHttpStatus(Map<String, Object> errorAttributes) Get the HTTP error status information from the error map.protected org.springframework.web.reactive.function.server.RouterFunction<org.springframework.web.reactive.function.server.ServerResponse>getRoutingFunction(org.springframework.boot.web.reactive.error.ErrorAttributes errorAttributes) Create aRouterFunctionthat can route and handle errors as JSON responses or HTML views.protected booleanisIncludeBindingErrors(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType produces) Determine if the errors attribute should be included.protected booleanisIncludeMessage(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType produces) Determine if the message attribute should be included.protected booleanisIncludeStackTrace(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType produces) Determine if the stacktrace attribute should be included.protected reactor.core.publisher.Mono<org.springframework.web.reactive.function.server.ServerResponse>renderErrorResponse(org.springframework.web.reactive.function.server.ServerRequest request) Render the error information as a JSON payload.protected reactor.core.publisher.Mono<org.springframework.web.reactive.function.server.ServerResponse>renderErrorView(org.springframework.web.reactive.function.server.ServerRequest request) Render the error information as an HTML view.Methods inherited from class org.springframework.boot.autoconfigure.web.reactive.error.AbstractErrorWebExceptionHandler
afterPropertiesSet, getError, getErrorAttributes, handle, isBindingErrorsEnabled, isMessageEnabled, isTraceEnabled, logError, renderDefaultErrorView, renderErrorView, setMessageReaders, setMessageWriters, setViewResolvers
-
Constructor Details
-
DefaultErrorWebExceptionHandler
public DefaultErrorWebExceptionHandler(org.springframework.boot.web.reactive.error.ErrorAttributes errorAttributes, WebProperties.Resources resources, ErrorProperties errorProperties, org.springframework.context.ApplicationContext applicationContext) Create a newDefaultErrorWebExceptionHandlerinstance.- Parameters:
errorAttributes- the error attributesresources- the resources configuration propertieserrorProperties- the error configuration propertiesapplicationContext- the current application context- Since:
- 2.4.0
-
-
Method Details
-
getRoutingFunction
protected org.springframework.web.reactive.function.server.RouterFunction<org.springframework.web.reactive.function.server.ServerResponse> getRoutingFunction(org.springframework.boot.web.reactive.error.ErrorAttributes errorAttributes) Description copied from class:AbstractErrorWebExceptionHandlerCreate aRouterFunctionthat can route and handle errors as JSON responses or HTML views.If the returned
RouterFunctiondoesn't route to aHandlerFunction, the original exception is propagated in the pipeline and can be processed by otherWebExceptionHandlers.- Specified by:
getRoutingFunctionin classAbstractErrorWebExceptionHandler- Parameters:
errorAttributes- theErrorAttributesinstance to use to extract error information- Returns:
- a
RouterFunctionthat routes and handles errors
-
renderErrorView
protected reactor.core.publisher.Mono<org.springframework.web.reactive.function.server.ServerResponse> renderErrorView(org.springframework.web.reactive.function.server.ServerRequest request) Render the error information as an HTML view.- Parameters:
request- the current request- Returns:
- a
Publisherof the HTTP response
-
renderErrorResponse
protected reactor.core.publisher.Mono<org.springframework.web.reactive.function.server.ServerResponse> renderErrorResponse(org.springframework.web.reactive.function.server.ServerRequest request) Render the error information as a JSON payload.- Parameters:
request- the current request- Returns:
- a
Publisherof the HTTP response
-
getErrorAttributeOptions
protected org.springframework.boot.web.error.ErrorAttributeOptions getErrorAttributeOptions(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType mediaType) -
isIncludeStackTrace
protected boolean isIncludeStackTrace(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType produces) Determine if the stacktrace attribute should be included.- Parameters:
request- the source requestproduces- the media type produced (orMediaType.ALL)- Returns:
- if the stacktrace attribute should be included
-
isIncludeMessage
protected boolean isIncludeMessage(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType produces) Determine if the message attribute should be included.- Parameters:
request- the source requestproduces- the media type produced (orMediaType.ALL)- Returns:
- if the message attribute should be included
-
isIncludeBindingErrors
protected boolean isIncludeBindingErrors(org.springframework.web.reactive.function.server.ServerRequest request, org.springframework.http.MediaType produces) Determine if the errors attribute should be included.- Parameters:
request- the source requestproduces- the media type produced (orMediaType.ALL)- Returns:
- if the errors attribute should be included
-
getHttpStatus
Get the HTTP error status information from the error map.- Parameters:
errorAttributes- the current error information- Returns:
- the error HTTP status
-
acceptsTextHtml
protected org.springframework.web.reactive.function.server.RequestPredicate acceptsTextHtml()Predicate that checks whether the current request explicitly support"text/html"media type.The "match-all" media type is not considered here.
- Returns:
- the request predicate
-