获取Request.Form.Files中的文件转换成byte数组

有些时候接收到客户端的文件需要再上传到另一服务中(当前这种情况不常见),我们应该怎么处理呢。

目前需求是这样的,客户端有文件上传到A服务中,A服务需要再把文件上传到B服务中,实现的方案是,A服务获取到Request.Form.Files中的文件保存到本地,然后再获取本地的文件上传到B服务中,在使用中大量的请求,这样的操作导致了磁盘读写非常高。

					string FileName = Request.Form.Files[0].FileName;
					if (!Directory.Exists("D:\\Test"))//创建文件夹,如果不存在则创建
                    {
                        Directory.CreateDirectory("D:\\Test");
                    }
                    string fullPath = "D:\\Test\\" + Request.Form.Files[0].FileName;//组合成要存储到的目录
                    string PC = "D:\\Test\\Receivefile\\" + "aaa_" + FileName ;//最后下载到的目录
                    using (var stream = new FileStream(fullPath, FileMode.Create))
                    {
                        Request.Form.Files[0].CopyTo(stream);
                    } 
            try
            {
                var fileName = System.IO.Path.GetFileName(PC );
                var client = new RestClient($"{123.123.123.123}api/uploadfile");
                var request = new RestRequest("", Method.Post);
                request.AlwaysMultipartFormData = true;
                request.AddHeader("Content-Type", "multipart/form-data");
                request.AddFile("file", PC );
                request.AddParameter("multipart/form-data", fileName, ParameterType.RequestBody);
                var response = client.Execute(request);
                return response.StatusCode == System.Net.HttpStatusCode.OK;
            }
            catch (Exception e)
            {
                return false;
            }

以上的操作需要先获取请求中的文件 保存到本地 然后再去上传,客户端如果很多请求多了服务器的磁盘读写就高,严重可能会导致宕机

我们可以改成直接读取请求中文件,转换成byte数组直接去上传,这样就减少了写入本地的操作

					string FileName = Request.Form.Files[0].FileName;
					Stream size = Request.Form.Files[0].OpenReadStream();//读取Request的文件
                    byte[] buffer = new byte[size.Length];//将Request转换为byte数组
                    size.Read(buffer, 0, buffer.Length);  
                    try
                    {
                        var client = new RestClient($"http://123.123.123.44:16000/api/uploadfile");
                        var request = new RestRequest("", Method.Post);
                        request.AlwaysMultipartFormData = true;
                        request.AddHeader("Content-Type", "multipart/form-data");
                        request.AddFile("file", buffer, FileName);
                        request.AddParameter("multipart/form-data", FileName , ParameterType.RequestBody);
                        var response = client.Execute(request);
                        if (response.StatusCode == System.Net.HttpStatusCode.OK)
                        {
                            return new T返回 { rec = "200", msg = "上传成功" };
                        }
                        return new T返回 { rec = "400", msg = "上传失败" };
                    }
                    catch (Exception e)
                    {
                        return new T返回 { rec = "400", msg = "上传失败" };
                    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在Java上传文件时出现"the request was rejected because no multipart boundary was found"的错误通常是由于请求缺少multipart边界引起的。multipart边界是用来分隔不同部分的标识符。 要解决这个问题,你可以采取以下步骤: 1. 确保你使用了正确的请求方法,通常是POST方法。 2. 确保你设置了正确的Content-Type头部信息。对于文件上传,Content-Type应该设置为"multipart/form-data"。 3. 在请求正文添加multipart边界。multipart边界应该以"--"开头,并且在最后一行以"--"结尾。边界字符串可以是任何你选择的字符串,只需确保它在请求正文是唯一的即可。 以下是一个示例代码片段,展示了如何使用Java上传文件并设置正确的multipart边界: ```java import java.io.File; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Path; import java.nio.file.StandardOpenOption; import java.util.Random; public class FileUploader { public static void main(String[] args) throws IOException { String url = "http://example.com/upload"; // 替换为实际的上传URL String filePath = "path/to/file.txt"; // 替换为要上传的文件路径 // 生成随机的multipart边界字符串 String boundary = generateBoundary(); // 读取文件内容 byte[] fileContent = Files.readAllBytes(Path.of(filePath)); // 构建请求正文 byte[] requestBody = buildRequestBody(fileContent, boundary); // 设置请求头部信息 HttpRequest request = HttpRequest.newBuilder() .uri(URI.create(url)) .header("Content-Type", "multipart/form-data; boundary=" + boundary) .POST(HttpRequest.BodyPublishers.ofByteArray(requestBody)) .build(); // 发送请求并处理响应 HttpClient client = HttpClient.newHttpClient(); HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString()); // 处理响应结果 System.out.println(response.statusCode()); System.out.println(response.body()); } private static String generateBoundary() { Random random = new Random(); return "---------------------------" + random.nextInt(999999999); } private static byte[] buildRequestBody(byte[] fileContent, String boundary) throws IOException { ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); PrintWriter writer = new PrintWriter(new OutputStreamWriter(outputStream, StandardCharsets.UTF_8), true); // 添加文件部分 writer.append("--").append(boundary).append("\r\n"); writer.append("Content-Disposition: form-data; name=\"file\"; filename=\"file.txt\"\r\n"); writer.append("Content-Type: text/plain\r\n"); writer.append("\r\n"); writer.flush(); outputStream.write(fileContent); outputStream.flush(); // 添加结束边界 writer.append("\r\n"); writer.append("--").append(boundary).append("--\r\n"); writer.flush(); return outputStream.toByteArray(); } } ``` 请注意,这只是一个简单的示例,实际的文件上传可能涉及更多的错误处理和逻辑。根据你的需求,你可能需要使用其他库或框架来处理文件上传。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

香煎三文鱼

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值