Class DefaultServerWebExchange
java.lang.Object
org.springframework.web.server.adapter.DefaultServerWebExchange
- All Implemented Interfaces:
- ServerWebExchange
- Direct Known Subclasses:
- MockServerWebExchange
Default implementation of 
ServerWebExchange.- Since:
- 5.0
- Author:
- Rossen Stoyanchev, Brian Clozel
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.springframework.web.server.ServerWebExchangeServerWebExchange.Builder
- 
Field SummaryFields inherited from interface org.springframework.web.server.ServerWebExchangeLOG_ID_ATTRIBUTE
- 
Constructor SummaryConstructorsConstructorDescriptionDefaultServerWebExchange(ServerHttpRequest request, ServerHttpResponse response, WebSessionManager sessionManager, ServerCodecConfigurer codecConfigurer, LocaleContextResolver localeContextResolver) 
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddUrlTransformer(Function<String, String> transformer) Register an additional URL transformation function for use withServerWebExchange.transformUrl(java.lang.String).booleancheckNotModified(String etag) An overloaded variant ofServerWebExchange.checkNotModified(String, Instant)with anETag(entity tag) value only.booleancheckNotModified(String eTag, Instant lastModified) Check whether the requested resource has been modified given the suppliedETag(entity tag) and last-modified timestamp as determined by the application.booleancheckNotModified(Instant lastModified) An overloaded variant ofServerWebExchange.checkNotModified(String, Instant)with a last-modified timestamp only.reactor.core.publisher.Mono<Void>Cleans up any storage used for multipart handling.Return theApplicationContextassociated with the web application, if it was initialized with one viaWebHttpHandlerBuilder.applicationContext(ApplicationContext).Return a mutable map of request attributes for the current exchange.reactor.core.publisher.Mono<MultiValueMap<String,String>> Return the form data from the body of the request if the Content-Type is"application/x-www-form-urlencoded"or an empty map otherwise.Return theLocaleContextusing the configuredLocaleContextResolver.Return a log message prefix to use to correlate messages for this exchange.reactor.core.publisher.Mono<MultiValueMap<String,Part>> Return the parts of a multipart request if the Content-Type is"multipart/form-data"or an empty map otherwise.<T extends Principal>
 reactor.core.publisher.Mono<T>Return the authenticated user for the request, if any.Return the current HTTP request.Return the current HTTP response.reactor.core.publisher.Mono<WebSession>Return the web session for the current request.booleanReturnstrueif the one of thecheckNotModifiedmethods in this contract were used and they returned true.transformUrl(String url) Transform the given url according to the registered transformation function(s).Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.web.server.ServerWebExchangegetAttribute, getAttributeOrDefault, getRequiredAttribute, mutate
- 
Constructor Details- 
DefaultServerWebExchangepublic DefaultServerWebExchange(ServerHttpRequest request, ServerHttpResponse response, WebSessionManager sessionManager, ServerCodecConfigurer codecConfigurer, LocaleContextResolver localeContextResolver) 
 
- 
- 
Method Details- 
getRequestDescription copied from interface:ServerWebExchangeReturn the current HTTP request.- Specified by:
- getRequestin interface- ServerWebExchange
 
- 
getResponseDescription copied from interface:ServerWebExchangeReturn the current HTTP response.- Specified by:
- getResponsein interface- ServerWebExchange
 
- 
getAttributesDescription copied from interface:ServerWebExchangeReturn a mutable map of request attributes for the current exchange.- Specified by:
- getAttributesin interface- ServerWebExchange
 
- 
getSessionDescription copied from interface:ServerWebExchangeReturn the web session for the current request. Always guaranteed to return an instance either matching to the session id requested by the client, or with a new session id either because the client did not specify one or because the underlying session had expired. Use of this method does not automatically create a session. SeeWebSessionfor more details.- Specified by:
- getSessionin interface- ServerWebExchange
 
- 
getPrincipalDescription copied from interface:ServerWebExchangeReturn the authenticated user for the request, if any.- Specified by:
- getPrincipalin interface- ServerWebExchange
 
- 
getFormDataDescription copied from interface:ServerWebExchangeReturn the form data from the body of the request if the Content-Type is"application/x-www-form-urlencoded"or an empty map otherwise.Note: calling this method causes the request body to be read and parsed in full and the resulting MultiValueMapis cached so that this method is safe to call more than once.- Specified by:
- getFormDatain interface- ServerWebExchange
 
- 
getMultipartDataDescription copied from interface:ServerWebExchangeReturn the parts of a multipart request if the Content-Type is"multipart/form-data"or an empty map otherwise.Note: calling this method causes the request body to be read and parsed in full and the resulting MultiValueMapis cached so that this method is safe to call more than once.Note:the contents of each part is not cached, and can only be read once. - Specified by:
- getMultipartDatain interface- ServerWebExchange
 
- 
cleanupMultipartDescription copied from interface:ServerWebExchangeCleans up any storage used for multipart handling.- Specified by:
- cleanupMultipartin interface- ServerWebExchange
- See Also:
 
- 
getLocaleContextDescription copied from interface:ServerWebExchangeReturn theLocaleContextusing the configuredLocaleContextResolver.- Specified by:
- getLocaleContextin interface- ServerWebExchange
 
- 
getApplicationContextDescription copied from interface:ServerWebExchangeReturn theApplicationContextassociated with the web application, if it was initialized with one viaWebHttpHandlerBuilder.applicationContext(ApplicationContext).- Specified by:
- getApplicationContextin interface- ServerWebExchange
- See Also:
 
- 
isNotModifiedpublic boolean isNotModified()Description copied from interface:ServerWebExchangeReturnstrueif the one of thecheckNotModifiedmethods in this contract were used and they returned true.- Specified by:
- isNotModifiedin interface- ServerWebExchange
 
- 
checkNotModifiedDescription copied from interface:ServerWebExchangeAn overloaded variant ofServerWebExchange.checkNotModified(String, Instant)with a last-modified timestamp only.- Specified by:
- checkNotModifiedin interface- ServerWebExchange
- Parameters:
- lastModified- the last-modified time
- Returns:
- whether the request qualifies as not modified
 
- 
checkNotModifiedDescription copied from interface:ServerWebExchangeAn overloaded variant ofServerWebExchange.checkNotModified(String, Instant)with anETag(entity tag) value only.- Specified by:
- checkNotModifiedin interface- ServerWebExchange
- Parameters:
- etag- the entity tag for the underlying resource.
- Returns:
- true if the request does not require further processing.
 
- 
checkNotModifiedDescription copied from interface:ServerWebExchangeCheck whether the requested resource has been modified given the suppliedETag(entity tag) and last-modified timestamp as determined by the application. Also transparently prepares the response, setting HTTP status, and adding "ETag" and "Last-Modified" headers when applicable. This method works with conditional GET/HEAD requests as well as with conditional POST/PUT/DELETE requests.Note: The HTTP specification recommends setting both ETag and Last-Modified values, but you can also use #checkNotModified(String)orServerWebExchange.checkNotModified(Instant).- Specified by:
- checkNotModifiedin interface- ServerWebExchange
- Parameters:
- eTag- the entity tag that the application determined for the underlying resource. This parameter will be padded with quotes (") if necessary.
- lastModified- the last-modified timestamp that the application determined for the underlying resource
- Returns:
- true if the request does not require further processing.
 
- 
transformUrlDescription copied from interface:ServerWebExchangeTransform the given url according to the registered transformation function(s). By default, this method returns the givenurl, though additional transformation functions can be registered withServerWebExchange.addUrlTransformer(java.util.function.Function<java.lang.String, java.lang.String>)- Specified by:
- transformUrlin interface- ServerWebExchange
- Parameters:
- url- the URL to transform
- Returns:
- the transformed URL
 
- 
addUrlTransformerDescription copied from interface:ServerWebExchangeRegister an additional URL transformation function for use withServerWebExchange.transformUrl(java.lang.String). The given function can be used to insert an id for authentication, a nonce for CSRF protection, etc.Note that the given function is applied after any previously registered functions. - Specified by:
- addUrlTransformerin interface- ServerWebExchange
- Parameters:
- transformer- a URL transformation function to add
 
- 
getLogPrefixDescription copied from interface:ServerWebExchangeReturn a log message prefix to use to correlate messages for this exchange. The prefix is based on the value of the attributeServerWebExchange.LOG_ID_ATTRIBUTEalong with some extra formatting so that the prefix can be conveniently prepended with no further formatting no separators required.- Specified by:
- getLogPrefixin interface- ServerWebExchange
- Returns:
- the log message prefix or an empty String if the
 ServerWebExchange.LOG_ID_ATTRIBUTEis not set.
 
 
-