Asp.net Core Web API - 从blob存储下载多个图像到zip文件(通过Axios get)
创始人
2024-09-15 13:00:56
0

以下是一个示例代码,演示了如何使用Asp.net Core Web API通过Axios get方法从Blob存储下载多个图像到Zip文件。

首先,确保你已经在项目中安装了以下NuGet包:

  • Microsoft.AspNetCore.Mvc
  • Microsoft.Extensions.Http
  • System.IO.Compression

然后,创建一个名为"ImagesController.cs"的控制器文件,并添加以下代码:

using Microsoft.AspNetCore.Mvc;
using System.IO;
using System.IO.Compression;
using System.Net.Http;
using System.Threading.Tasks;

[Route("api/[controller]")]
[ApiController]
public class ImagesController : ControllerBase
{
    private readonly IHttpClientFactory _httpClientFactory;

    public ImagesController(IHttpClientFactory httpClientFactory)
    {
        _httpClientFactory = httpClientFactory;
    }

    [HttpGet("download")]
    public async Task DownloadImages()
    {
        var imagesUrls = new string[] {
            "https://yourblobstorageurl/image1.png",
            "https://yourblobstorageurl/image2.png",
            "https://yourblobstorageurl/image3.png"
        };

        using (var memoryStream = new MemoryStream())
        {
            using (var archive = new ZipArchive(memoryStream, ZipArchiveMode.Create, true))
            {
                foreach (var imageUrl in imagesUrls)
                {
                    var fileName = imageUrl.Substring(imageUrl.LastIndexOf('/') + 1);

                    using (var httpClient = _httpClientFactory.CreateClient())
                    {
                        var imageBytes = await httpClient.GetByteArrayAsync(imageUrl);

                        var entry = archive.CreateEntry(fileName);

                        using (var entryStream = entry.Open())
                        {
                            await entryStream.WriteAsync(imageBytes, 0, imageBytes.Length);
                        }
                    }
                }
            }

            memoryStream.Seek(0, SeekOrigin.Begin);
            return File(memoryStream, "application/octet-stream", "images.zip");
        }
    }
}

在上述代码中,我们创建了一个名为"DownloadImages"的GET动作,用于下载多个图像文件。首先,我们定义了要下载的图像URL列表。然后,我们创建一个内存流和一个ZipArchive实例,用于将图像文件添加到Zip文件中。

接下来,我们使用IHttpClientFactory创建一个HttpClient实例,以便使用Axios get方法从Blob存储下载图像文件的字节数组。然后,我们在Zip文件中创建一个条目,并将图像字节数组写入条目流中。

最后,我们将内存流的位置重置为起始位置,然后将其作为文件返回给客户端,以便下载Zip文件。

请注意,你需要将"yourblobstorageurl"替换为实际的Blob存储URL,以及根据你的需求修改图像文件名和URL列表。

希望这个示例对你有所帮助!

相关内容

热门资讯

记者揭秘!智星菠萝辅助(透视辅... 记者揭秘!智星菠萝辅助(透视辅助)拱趴大菠萝辅助神器,扑克教程(有挂细节);模式供您选择,了解更新找...
一分钟揭秘!约局吧能能开挂(透... 一分钟揭秘!约局吧能能开挂(透视辅助)hhpoker辅助靠谱,2024新版教程(有挂教学);约局吧能...
透视辅助!wepoker模拟器... 透视辅助!wepoker模拟器哪个好用(脚本)hhpoker辅助挂是真的,科技教程(有挂技巧);囊括...
透视代打!hhpkoer辅助器... 透视代打!hhpkoer辅助器视频(辅助挂)pokemmo脚本辅助,2024新版教程(有挂教程);风...
透视了解!约局吧德州真的有透视... 透视了解!约局吧德州真的有透视挂(透视脚本)德州局HHpoker透视脚本,必胜教程(有挂分析);亲,...
六分钟了解!wepoker挂底... 六分钟了解!wepoker挂底牌(透视)德普之星开辅助,详细教程(有挂解密);德普之星开辅助是一种具...
9分钟了解!wpk私人辅助(透... 9分钟了解!wpk私人辅助(透视)hhpoker德州透视,插件教程(有挂教学);风靡全球的特色经典游...
推荐一款!wepoker究竟有... 推荐一款!wepoker究竟有透视(脚本)哈糖大菠萝开挂,介绍教程(有挂技术);囊括全国各种wepo...
每日必备!wepoker有人用... 每日必备!wepoker有人用过(脚本)wpk有那种辅助,线上教程(有挂规律);wepoker有人用...
玩家必备教程!wejoker私... 玩家必备教程!wejoker私人辅助软件(脚本)哈糖大菠萝可以开挂,可靠技巧(有挂神器)申哈糖大菠萝...