Class DefaultErrorWebExceptionHandler
- All Implemented Interfaces:
InitializingBean
,ErrorWebExceptionHandler
,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
- Author:
- Brian Clozel, Scott Frederick, Moritz Halbritter
-
Constructor Summary
ConstructorDescriptionDefaultErrorWebExceptionHandler
(ErrorAttributes errorAttributes, WebProperties.Resources resources, ErrorProperties errorProperties, ApplicationContext applicationContext) Create a newDefaultErrorWebExceptionHandler
instance. -
Method Summary
Modifier and TypeMethodDescriptionprotected RequestPredicate
Predicate that checks whether the current request explicitly support"text/html"
media type.protected ErrorAttributeOptions
getErrorAttributeOptions
(ServerRequest request, MediaType mediaType) protected int
getHttpStatus
(Map<String, Object> errorAttributes) Get the HTTP error status information from the error map.protected RouterFunction<ServerResponse>
getRoutingFunction
(ErrorAttributes errorAttributes) Create aRouterFunction
that can route and handle errors as JSON responses or HTML views.protected boolean
isIncludeBindingErrors
(ServerRequest request, MediaType produces) Determine if the errors attribute should be included.protected boolean
isIncludeMessage
(ServerRequest request, MediaType produces) Determine if the message attribute should be included.protected boolean
isIncludePath
(ServerRequest request, MediaType produces) Determine if the path attribute should be included.protected boolean
isIncludeStackTrace
(ServerRequest request, MediaType produces) Determine if the stacktrace attribute should be included.protected reactor.core.publisher.Mono<ServerResponse>
renderErrorResponse
(ServerRequest request) Render the error information as a JSON payload.protected reactor.core.publisher.Mono<ServerResponse>
renderErrorView
(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, isPathEnabled, isTraceEnabled, logError, renderDefaultErrorView, renderErrorView, setMessageReaders, setMessageWriters, setViewResolvers
-
Constructor Details
-
DefaultErrorWebExceptionHandler
public DefaultErrorWebExceptionHandler(ErrorAttributes errorAttributes, WebProperties.Resources resources, ErrorProperties errorProperties, ApplicationContext applicationContext) Create a newDefaultErrorWebExceptionHandler
instance.- Parameters:
errorAttributes
- the error attributesresources
- the resources configuration propertieserrorProperties
- the error configuration propertiesapplicationContext
- the current application context- Since:
- 2.4.0
-
-
Method Details
-
getRoutingFunction
Description copied from class:AbstractErrorWebExceptionHandler
Create aRouterFunction
that can route and handle errors as JSON responses or HTML views.If the returned
RouterFunction
doesn't route to aHandlerFunction
, the original exception is propagated in the pipeline and can be processed by otherWebExceptionHandler
s.- Specified by:
getRoutingFunction
in classAbstractErrorWebExceptionHandler
- Parameters:
errorAttributes
- theErrorAttributes
instance to use to extract error information- Returns:
- a
RouterFunction
that routes and handles errors
-
renderErrorView
Render the error information as an HTML view.- Parameters:
request
- the current request- Returns:
- a
Publisher
of the HTTP response
-
renderErrorResponse
Render the error information as a JSON payload.- Parameters:
request
- the current request- Returns:
- a
Publisher
of the HTTP response
-
getErrorAttributeOptions
protected ErrorAttributeOptions getErrorAttributeOptions(ServerRequest request, MediaType mediaType) -
isIncludeStackTrace
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
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
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
-
isIncludePath
Determine if the path attribute should be included.- Parameters:
request
- the source requestproduces
- the media type produced (orMediaType.ALL
)- Returns:
- if the path attribute should be included
- Since:
- 3.3.0
-
getHttpStatus
Get the HTTP error status information from the error map.- Parameters:
errorAttributes
- the current error information- Returns:
- the error HTTP status
-
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
-