HttpRequest增加setFixedContentLength方法

This commit is contained in:
Looly 2024-09-14 15:31:22 +08:00
parent 975cfa0fb1
commit 277ecc90dc
2 changed files with 36 additions and 29 deletions

View File

@ -2,7 +2,7 @@
# 🚀Changelog
-------------------------------------------------------------------------------------------------------------
# 5.8.33(2024-09-13)
# 5.8.33(2024-09-14)
### 🐣新特性
* 【core 】 SyncFinisher增加setExecutorService方法issue#IANKQ1@Gitee
@ -11,7 +11,7 @@
* 【crypto 】 SM2解密时兼容GmSSL非压缩省略的04头的密文issue#IAP1QJ@Gitee
* 【core 】 兼容NumberUtil.add方法传入整型自动类型转换为浮点类型的精度丢失问题pr#3721@Github
* 【core 】 ModifierUtil明确注释并增加hasAllModifiers方法issue#IAQ2U0@Gitee
* 【http 】 HttpRequest增加setFixedLengthStreamingMode方法issue#3462@Github
* 【http 】 HttpRequest增加setFixedContentLength方法issue#3462@Github
### 🐞Bug修复
* 【json 】 修复JSONConfig.setDateFormat设置后toBean无效问题issue#3713@Github

View File

@ -238,6 +238,10 @@ public class HttpRequest extends HttpBase<HttpRequest> {
* 重定向次数计数器内部使用
*/
private int redirectCount;
/**
* 固定长度用于设置HttpURLConnection.setFixedLengthStreamingMode默认为0表示使用默认值默认值由HttpURLConnection内部决定通常为0
*/
private long fixedContentLength;
/**
* 构造URL编码默认使用UTF-8
@ -358,8 +362,8 @@ public class HttpRequest extends HttpBase<HttpRequest> {
* @return this
* @since 5.8.33
*/
public HttpRequest setFixedLengthStreamingMode(long contentLength){
this.httpConnection.setFixedLengthStreamingMode(contentLength);
public HttpRequest setFixedContentLength(long contentLength) {
this.fixedContentLength = contentLength;
return this;
}
@ -878,7 +882,8 @@ public class HttpRequest extends HttpBase<HttpRequest> {
/**
* 自动重定向时是否处理cookie
* @param followRedirectsCookie 自动重定向时是否处理cookie
*
* @param followRedirectsCookie 自动重定向时是否处理cookie
* @return this
*/
public HttpRequest setFollowRedirectsCookie(boolean followRedirectsCookie) {
@ -1228,19 +1233,21 @@ public class HttpRequest extends HttpBase<HttpRequest> {
}
this.httpConnection = HttpConnection
// issue#I50NHQ
// 在生成正式URL前设置自定义编码
.create(this.url.setCharset(this.charset).toURL(this.urlHandler), config.proxy)//
.setConnectTimeout(config.connectionTimeout)//
.setReadTimeout(config.readTimeout)//
.setMethod(this.method)//
.setHttpsInfo(config.hostnameVerifier, config.ssf)//
// 关闭JDK自动转发采用手动转发方式
.setInstanceFollowRedirects(false)
// 流方式上传数据
.setChunkedStreamingMode(config.blockSize)
// 覆盖默认Header
.header(this.headers, false);
// issue#I50NHQ
// 在生成正式URL前设置自定义编码
.create(this.url.setCharset(this.charset).toURL(this.urlHandler), config.proxy)//
.setConnectTimeout(config.connectionTimeout)//
.setReadTimeout(config.readTimeout)//
.setMethod(this.method)//
.setHttpsInfo(config.hostnameVerifier, config.ssf)//
// 关闭JDK自动转发采用手动转发方式
.setInstanceFollowRedirects(false)
// 流方式上传数据
.setChunkedStreamingMode(config.blockSize)
// issue#3462 自定义body长度
.setFixedLengthStreamingMode(this.fixedContentLength)
// 覆盖默认Header
.header(this.headers, false);
if (null != this.cookie) {
// 当用户自定义Cookie时全局Cookie自动失效
@ -1321,7 +1328,7 @@ public class HttpRequest extends HttpBase<HttpRequest> {
query = null;
}
redirectUrl = UrlBuilder.of(this.url.getScheme(), this.url.getHost(), this.url.getPort()
, location, query, null, this.charset);
, location, query, null, this.charset);
} else {
redirectUrl = UrlBuilder.ofHttpWithoutEncode(location);
}
@ -1337,7 +1344,7 @@ public class HttpRequest extends HttpBase<HttpRequest> {
redirectCount++;
// 重定向可选是否走过滤器
return doExecute(isAsync, config.interceptorOnRedirect ? config.requestInterceptors : null,
config.interceptorOnRedirect ? config.responseInterceptors : null);
config.interceptorOnRedirect ? config.responseInterceptors : null);
}
}
}
@ -1353,9 +1360,9 @@ public class HttpRequest extends HttpBase<HttpRequest> {
private void send() throws IORuntimeException {
try {
if (Method.POST.equals(this.method) //
|| Method.PUT.equals(this.method) //
|| Method.DELETE.equals(this.method) //
|| this.isRest) {
|| Method.PUT.equals(this.method) //
|| Method.DELETE.equals(this.method) //
|| this.isRest) {
if (isMultipart()) {
sendMultipart(); // 文件上传表单
} else {
@ -1392,7 +1399,7 @@ public class HttpRequest extends HttpBase<HttpRequest> {
*
* @return body
*/
private RequestBody createBody(){
private RequestBody createBody() {
// Write的时候会优先使用body中的内容write时自动关闭OutputStream
if (null != this.body) {
return ResourceBody.create(this.body);
@ -1410,9 +1417,9 @@ public class HttpRequest extends HttpBase<HttpRequest> {
private void sendMultipart() throws IOException {
final RequestBody body;
// issue#3158当用户自定义为multipart同时传入body则不做单独处理
if(null == form && null != this.body) {
if (null == form && null != this.body) {
body = ResourceBody.create(this.body);
}else{
} else {
final MultipartBody multipartBody = MultipartBody.create(this.form, this.charset);
//设置表单类型为Multipart文件上传
this.httpConnection.header(Header.CONTENT_TYPE, multipartBody.getContentType(), true);
@ -1431,8 +1438,8 @@ public class HttpRequest extends HttpBase<HttpRequest> {
*/
private boolean isIgnoreResponseBody() {
return Method.HEAD == this.method //
|| Method.CONNECT == this.method //
|| Method.TRACE == this.method;
|| Method.CONNECT == this.method //
|| Method.TRACE == this.method;
}
/**
@ -1453,7 +1460,7 @@ public class HttpRequest extends HttpBase<HttpRequest> {
final String contentType = header(Header.CONTENT_TYPE);
return StrUtil.isNotEmpty(contentType) &&
contentType.startsWith(ContentType.MULTIPART.getValue());
contentType.startsWith(ContentType.MULTIPART.getValue());
}
/**