.NET使用HttpClient以multipart/form-data形式post上传文件及其相关参数

487d5857b5a37f6e804296e31f324e68.png

4be622a9f1e8dd2b2b4473d616c0b570.jpeg

前言:

  本次要讲的是使用.Net HttpClient拼接multipark/form-data形式post上传文件和相关参数,并接收到上传文件成功后返回过来的结果(图片地址,和是否成功)。可能有很多人会说用ajax不是就可以轻松的实现吗?的确是在不存在跨域问题的前提下使用ajax上传文件,接收返回结果是最佳的选择。无奈的是我们对接的是第三方的一个上传图片的接口,而且对方并没有对我们的域名设置允许跨域,为了能够解决这一问题我们只能够通过后端请求避免跨域问题。

什么是multipart/form-data请求:

关于multipart/form-data详情查看:https://www.cnblogs.com/tylerdonet/p/5722858.html

Html上传图片按钮:

<div class="cover-hd">
<a href="javascript:;" class="a-uploadCustom">
<input type="file" id="Logoimg" onchange="OnchangeImage(this)" /></a>
</div>

使用ajax将图片文件流和相关参数传递到后端进行拼接:

注意:因为我这里调用第三方接口需要传递(appid应用程序唯一标识,random随机数,和sign签名)

<script type="text/javascript">
    //后端图片上传
    function OnchangeImage(obj) {
        var formData = new FormData();
        var files = $(obj).prop('files'); //获取到文件列表
        console.log(files[0]);
        formData.append("imgType", 1);
        formData.append("appId","你需要传递的参数");
        formData.append("random", "你需要传递的参数");
        formData.append("file", files[0]);//图片文件流
        formData.append("sign", "你需要传递的参数");


        console.log(formData);
        jQuery.support.cors = true;
        $.ajax({
            async: true,
            contentType: false, //头部请求内容格式
            dataType: 'json',
            type: 'post',
            data:formData,
            // 告诉jQuery不要去处理发送的数据
            processData: false,
            url: "@Url.Action("ImageUpload", "MtVirtualStore")",//后端接收图片接口
            success: function(data) {
                //后端Httpclient请求成功后返回过来的结果
                console.log(data);
            }
        });
    }
</script>

后端接收图片和参数,并将图片文件流转化为图片字节类型数据:

//接收前端图片文件信息
[HttpPost]
public JsonResult ImageUpload(FormContext context)
{
HttpPostedFileBase fileData = Request.Files[0];
string appId=Request["appId"];
string random=Request["random"];
string sign=Request["sign"];
string imgType=Request["imgType"];
if (fileData != null)
{
try{
string fileName = Path.GetFileName(fileData.FileName);//原始文件名称
byte[] byteFileData = ReadFileBytes(fileData);//文件流转为字节流


var resultContext =HttpClientPostUpload(byteFileData,appId,random,sign,imgType, fileName);


return Json(new { code = 1, list = resultContext,msg="上传成功~"});
}
catch (Exception ex)
{
return Json(new { code = 0, msg = ex.Message });
}
}
else
{
return Json(new { code = 0, msg = "图片上传失败,请稍后再试~" });
}
}
        
//文件流转化为字节
/// <summary>
/// 文件流类型转化字节类型
/// </summary>
/// <param name="fileData">文件流数据</param>
/// <returns></returns>
private byte[] ReadFileBytes(HttpPostedFileBase fileData)
{
byte[] data;
using (Stream inputStream = fileData.InputStream)
{
MemoryStream memoryStream = inputStream as MemoryStream;
if (memoryStream == null)
{
memoryStream = new MemoryStream();
inputStream.CopyTo(memoryStream);
}
data = memoryStream.ToArray();
}
return data;
}

重点,HttpClient拼接multipart/form-data形式参数post提交数据:

/// <summary>
/// 向目标地址提交图片文件参数数据
/// </summary>
/// <param name="bmpBytes">图片字节流</param>
/// <param name="appId">appid</param>
/// <param name="random">随机数</param> 
/// <param name="sign">签名</param>
/// <param name="imgType">上传图片类型</param>     
/// <param name="fileName">图片名称</param>
/// <returns></returns>
public string HttpClientPostUpload(byte [] bmpBytes, string appId, string random,string sign,string imgType,string fileName)
{
using (var client = new HttpClient())
{
List<ByteArrayContent> list = new List<ByteArrayContent>();


var dataContent = new ByteArrayContent(Encoding.UTF8.GetBytes(appId));
dataContent.Headers.ContentDisposition = new ContentDispositionHeaderValue("form-data")//内容处置标头
{
Name = "appId"
};
list.Add(dataContent);


var dataContent2 = new ByteArrayContent(Encoding.UTF8.GetBytes(imgType));
dataContent2.Headers.ContentDisposition = new ContentDispositionHeaderValue("form-data")
{
Name = "imgType"
};
list.Add(dataContent2);


var dataContent3 = new ByteArrayContent(Encoding.UTF8.GetBytes(random));
dataContent3.Headers.ContentDisposition = new ContentDispositionHeaderValue("form-data")
{
Name = "random"
};
list.Add(dataContent3);


var dataContent4 = new ByteArrayContent(Encoding.UTF8.GetBytes(sign));
dataContent4.Headers.ContentDisposition = new ContentDispositionHeaderValue("form-data")
{
Name = "sign"
};
list.Add(dataContent4);var fileContent = new ByteArrayContent(bmpBytes);//填充图片字节
fileContent.Headers.ContentDisposition = new ContentDispositionHeaderValue("form-data")
{
Name="file",
FileName=fileName
};
list.Add(fileContent);


using (var content =new MultipartFormDataContent())
{
Action<List<ByteArrayContent>> act = (dataContents) =>
{//声明一个委托,该委托的作用就是将ByteArrayContent集合加入到MultipartFormDataContent中
foreach (var byteArrayContent in dataContents)
{
content.Add(byteArrayContent);
}
};


act(list);//执行act
try
{
var result = client.PostAsync("https://xxxxxx.com/imageUpload/", content).Result;//post请求
return result.Content.ReadAsStringAsync().Result;
}
catch (Exception ex)
{
return ex.Message;
}


}
}
}

使用Fiddler 4 抓包查看请求的参数:

因为我们没有办法看到我们所拼接成功后的multipark/form-data形式的数据,想要看到对应拼接的请求参数可以使用 Fiddler 4 抓包工具查看:

关于Fiddler 4抓包工具的使用可以阅读该篇博客:https://www.jianshu.com/p/55f7be58a7e4

抓包获取到的multipark/form-data形式的请求参数如下图:

5d5f9630c4896f8fcbd70e5b9a841028.png

be7c7aa362f14b578ca4caf166ff9cfc.gif

4e56ea30bf0cfbca6252712ae18c2fb0.gif

b10272ad9e0b891977891e4e0b3b3958.jpeg


学习是一个永无止境的过程,你知道的越多,你不知道的也会越多,在有限的时间内坚持每天多学一点,你一定能成为你想要成为的那个人。不积跬步无以至千里,不积小流无以成江河!!!

f0a08f9c39e40537a68b443519cc0dc8.gif

See you next good day

78545c30a384f00c91f12401b93337b5.gif

使用httpclient进行multipart/form-data数据的上传,需要进行以下步骤: 1. 创建HttpPost对象,并设置URL地址。 2. 创建MultipartEntityBuilder对象,并设置字符编码,以及添加文件和参数。 3. 将MultipartEntityBuilder对象转换为HttpEntity对象,并设置到HttpPost对象中。 4. 创建CloseableHttpClient对象,并执行HttpPost请求。 5. 获取HttpResponse响应对象,判断响应状态码是否为200。 6. 解析HttpResponse响应内容。 下面是一个示例代码: ``` // 创建HttpPost对象 HttpPost httpPost = new HttpPost(uploadUrl); // 创建MultipartEntityBuilder对象 MultipartEntityBuilder builder = MultipartEntityBuilder.create().setCharset(Charset.forName("UTF-8")).setMode(HttpMultipartMode.BROWSER_COMPATIBLE); // 添加文件和参数 File file = new File(filePath); builder.addBinaryBody("file", file, ContentType.DEFAULT_BINARY, file.getName()); builder.addTextBody("param1", "value1"); // 将MultipartEntityBuilder对象转换为HttpEntity对象 HttpEntity entity = builder.build(); httpPost.setEntity(entity); // 创建CloseableHttpClient对象,并执行HttpPost请求 CloseableHttpClient httpClient = HttpClients.createDefault(); HttpResponse response = httpClient.execute(httpPost); // 判断响应状态码是否为200 if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { // 解析HttpResponse响应内容 HttpEntity responseEntity = response.getEntity(); String responseContent = EntityUtils.toString(responseEntity, "UTF-8"); System.out.println(responseContent); } // 关闭CloseableHttpClient对象 httpClient.close(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值