zoukankan      html  css  js  c++  java
  • 下载文件(API接口,Angularjs前端)

    最近在项目中,实现web api文件下载功能。

    文件是存储于数据库中。

    文件内容是vbinary数据类型,当然数据类型为image也没有问题的。

    参考下面代码示例:

     [HttpPost]
            public async Task<HttpResponseMessage> DownloadFile(JObject jObj)
            {
                var jsonStr = JsonConvert.SerializeObject(jObj);
                var jsonParams = JsonConvert.DeserializeObject<dynamic>(jsonStr);
    
                BarCode bc = new BarCode();
                bc.BarCode_nbr = jsonParams.BarCode_nbr;
    
                BarCodeEntity bce = new BarCodeEntity();
                var barcode = bce.BarCodes(bc).FirstOrDefault();
    
                HttpResponseMessage response = Request.CreateResponse(HttpStatusCode.OK);
    
                string physicalPath = HttpContext.Current.Server.MapPath("~/Temp/") + barcode.FileName;
    
                byte[] buffer = (byte[])barcode.QrCode;
    
                if (!File.Exists(physicalPath))
                {
                    using (FileStream fileStream = File.Create(physicalPath))
                    {
                        fileStream.Write(buffer, 0, buffer.Length);
                    }
                }
    
                response.Content = new ByteArrayContent(buffer);
                response.Content.Headers.ContentLength = buffer.LongLength;
                response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment");
                response.Content.Headers.ContentDisposition.FileName = barcode.FileName;
                response.Content.Headers.ContentType = new MediaTypeHeaderValue(MimeMapping.GetMimeMapping(barcode.FileName));
                return await Task.FromResult(response);
            }
    Source Code

    然后,前端是呼叫接口:

    var arg = {};
                arg.BarCode_nbr = qr.BarCode_nbr;
    
                fetch('/api/IoSvc/DownloadFile', {
                    method: 'POST',
                    headers: {
                        'Content-Type': 'application/json',
                    },
                    body: JSON.stringify(arg),
                })
                    .then(res => res.blob())
                    .then(data => {
                        let blobUrl = window.URL.createObjectURL(data);
                        const a = document.createElement('a');
                        a.style.display = 'none';
                        a.download = qr.FileName;
                        a.href = blobUrl;
                        a.click();
                    });
    Source Code

    效果:

  • 相关阅读:
    如何配置wamp多站点主机
    一些类和对象问题的探索,简单易懂的命名空间及use的使用
    [4] Git使用流程
    [正则] JS常用正则
    [3] Django返回json数据
    [8] Eclipse各版本代号一览表以及官网上有很多版本的eclipse的比较
    [7] MySQL数据库--学生管理系统数据库设计
    [11]Docker02 Docker重要概念
    [12]Docker03 Centos7安装Docker
    [小程序]小程序环境搭建
  • 原文地址:https://www.cnblogs.com/insus/p/13521726.html
Copyright © 2011-2022 走看看