Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
爱吃血肠
spring-framework
提交
59d3721a
S
spring-framework
项目概览
爱吃血肠
/
spring-framework
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
spring-framework
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
59d3721a
编写于
6月 24, 2016
作者:
S
Sebastien Deleuze
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Support default content type in CodecHttpMessageConverter
上级
52325a21
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
19 addition
and
1 deletion
+19
-1
spring-web-reactive/src/main/java/org/springframework/http/converter/reactive/CodecHttpMessageConverter.java
...rk/http/converter/reactive/CodecHttpMessageConverter.java
+19
-1
未找到文件。
spring-web-reactive/src/main/java/org/springframework/http/converter/reactive/CodecHttpMessageConverter.java
浏览文件 @
59d3721a
...
...
@@ -39,6 +39,7 @@ import org.springframework.http.support.MediaTypeUtils;
* {@link Encoder} and {@link Decoder}.
*
* @author Arjen Poutsma
* @author Sebastien Deleuze
*/
public
class
CodecHttpMessageConverter
<
T
>
implements
HttpMessageConverter
<
T
>
{
...
...
@@ -132,11 +133,28 @@ public class CodecHttpMessageConverter<T> implements HttpMessageConverter<T> {
}
HttpHeaders
headers
=
outputMessage
.
getHeaders
();
if
(
headers
.
getContentType
()
==
null
)
{
headers
.
setContentType
(
contentType
);
MediaType
contentTypeToUse
=
contentType
;
if
(
contentType
==
null
||
contentType
.
isWildcardType
()
||
contentType
.
isWildcardSubtype
())
{
contentTypeToUse
=
getDefaultContentType
(
type
);
}
headers
.
setContentType
(
contentTypeToUse
);
}
DataBufferFactory
dataBufferFactory
=
outputMessage
.
bufferFactory
();
Flux
<
DataBuffer
>
body
=
this
.
encoder
.
encode
(
inputStream
,
dataBufferFactory
,
type
,
contentType
);
return
outputMessage
.
writeWith
(
body
);
}
/**
* Returns the default content type for the given type. Called when {@link #write}
* is invoked without a specified content type parameter.
* <p>By default, this returns a {@link MediaType} created using the first element of
* the encoder {@link Encoder#getEncodableMimeTypes() encodableMimeTypes} property, if any.
* Can be overridden in subclasses.
* @param type the type to return the content type for
* @return the content type, or {@code null} if not known
*/
protected
MediaType
getDefaultContentType
(
ResolvableType
type
)
{
return
(!
this
.
writableMediaTypes
.
isEmpty
()
?
this
.
writableMediaTypes
.
get
(
0
)
:
null
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录