Fix AbstractMessageConverter not delegating to ContentTypeResolver when message header is null #29768
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Versions
Problems
DefaultContentTypeResolver#resolve
will returndefaultMimeType
ifnull
is passed asMessageHeaders
.spring-framework/spring-messaging/src/main/java/org/springframework/messaging/converter/DefaultContentTypeResolver.java
Lines 58 to 63 in 0fbc94f
However,
AbstractMessageConverter#getMimeType
does not call thecontentTypeResolver
ifnull
is passed asMessageHeaders
.spring-framework/spring-messaging/src/main/java/org/springframework/messaging/converter/AbstractMessageConverter.java
Lines 252 to 255 in 0fbc94f
Because of this, even if
DefaultContentTypeResolver#defaultMimeType
is set properly, it may be ignored.Fixes
ContentTypeResolver#resolve
acceptsnull
, soMessageConverter
should always delegate resolution to it.Fix
AbstractMessageConverter#getMimeType
not checking the value ofMessageHeaders
.