mirror of
https://gitee.com/binary/weixin-java-tools.git
synced 2025-10-29 17:48:50 +08:00
fix #211 上传素材时如果文件名是中文会乱码
This commit is contained in:
@ -11,6 +11,7 @@ import org.apache.http.client.config.RequestConfig;
|
|||||||
import org.apache.http.client.methods.CloseableHttpResponse;
|
import org.apache.http.client.methods.CloseableHttpResponse;
|
||||||
import org.apache.http.client.methods.HttpPost;
|
import org.apache.http.client.methods.HttpPost;
|
||||||
import org.apache.http.entity.ContentType;
|
import org.apache.http.entity.ContentType;
|
||||||
|
import org.apache.http.entity.mime.HttpMultipartMode;
|
||||||
import org.apache.http.entity.mime.MultipartEntityBuilder;
|
import org.apache.http.entity.mime.MultipartEntityBuilder;
|
||||||
|
|
||||||
import me.chanjar.weixin.common.bean.result.WxError;
|
import me.chanjar.weixin.common.bean.result.WxError;
|
||||||
@ -35,6 +36,7 @@ public class MediaUploadRequestExecutor implements RequestExecutor<WxMediaUpload
|
|||||||
HttpEntity entity = MultipartEntityBuilder
|
HttpEntity entity = MultipartEntityBuilder
|
||||||
.create()
|
.create()
|
||||||
.addBinaryBody("media", file)
|
.addBinaryBody("media", file)
|
||||||
|
.setMode(HttpMultipartMode.RFC6532)
|
||||||
.build();
|
.build();
|
||||||
httpPost.setEntity(entity);
|
httpPost.setEntity(entity);
|
||||||
httpPost.setHeader("Content-Type", ContentType.MULTIPART_FORM_DATA.toString());
|
httpPost.setHeader("Content-Type", ContentType.MULTIPART_FORM_DATA.toString());
|
||||||
|
|||||||
@ -13,6 +13,7 @@ import org.apache.http.client.config.RequestConfig;
|
|||||||
import org.apache.http.client.methods.CloseableHttpResponse;
|
import org.apache.http.client.methods.CloseableHttpResponse;
|
||||||
import org.apache.http.client.methods.HttpPost;
|
import org.apache.http.client.methods.HttpPost;
|
||||||
import org.apache.http.entity.ContentType;
|
import org.apache.http.entity.ContentType;
|
||||||
|
import org.apache.http.entity.mime.HttpMultipartMode;
|
||||||
import org.apache.http.entity.mime.MultipartEntityBuilder;
|
import org.apache.http.entity.mime.MultipartEntityBuilder;
|
||||||
import org.apache.http.entity.mime.content.InputStreamBody;
|
import org.apache.http.entity.mime.content.InputStreamBody;
|
||||||
import org.apache.http.impl.client.CloseableHttpClient;
|
import org.apache.http.impl.client.CloseableHttpClient;
|
||||||
@ -36,7 +37,9 @@ public class MaterialUploadRequestExecutor implements RequestExecutor<WxMpMateri
|
|||||||
}
|
}
|
||||||
BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream(file));
|
BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream(file));
|
||||||
MultipartEntityBuilder multipartEntityBuilder = MultipartEntityBuilder.create();
|
MultipartEntityBuilder multipartEntityBuilder = MultipartEntityBuilder.create();
|
||||||
multipartEntityBuilder.addPart("media", new InputStreamBody(bufferedInputStream, material.getName()));
|
multipartEntityBuilder
|
||||||
|
.addPart("media", new InputStreamBody(bufferedInputStream, material.getName()))
|
||||||
|
.setMode(HttpMultipartMode.RFC6532);
|
||||||
Map<String, String> form = material.getForm();
|
Map<String, String> form = material.getForm();
|
||||||
if (material.getForm() != null) {
|
if (material.getForm() != null) {
|
||||||
multipartEntityBuilder.addTextBody("description", WxGsonBuilder.create().toJson(form));
|
multipartEntityBuilder.addTextBody("description", WxGsonBuilder.create().toJson(form));
|
||||||
|
|||||||
Reference in New Issue
Block a user