.Net WebAPI 高速下载文件接口实现
来源:互联网 发布:ubuntu制作u盘启动工具 编辑:程序博客网 时间:2024/04/27 13:31
接触WebAPI一年多了,感觉是个承上启下,开创未来的技术。老一辈程序员写接口就像写方法一样,不需要了解太多网页的知识,却可以在浏览器中访问这些接口;由于是基于HTTP协议,因此不管是PC、手机还是嵌入式均可顺利访问。对于当下软件多终端的设计结构来说,这就像是量身订做的一样。
在开发的过程中遇到了一些问题,大部分都可通过百度找到解决方案,但是有一个问题却一直没有很好地解决,那就是文件下载速度的问题。
网上找到的WebAPI下载文件的代码大都是以下方式:
using System;using System.Collections;using System.Collections.Generic;using System.IO;using System.Linq;using System.Net;using System.Net.Http;using System.Runtime.Remoting.Contexts;using System.Text;using System.Threading.Tasks;using System.Web;using System.Web.Http;using System.Web.Http.Cors;using System.Net.Http.Headers;namespace Service.Controller{ public partial class APIController : ApiController { public HttpResponseMessage GetFileResponse(string FilePath, string FileName = null, string ContentType = "application/octet-stream") { FileStream fs; HttpResponseMessage result; fs = new FileStream(FilePath, FileMode.Open, FileAccess.Read, FileShare.Read); result = new HttpResponseMessage(System.Net.HttpStatusCode.OK) { Content = new StreamContent(fs) }; result.Content.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue(ContentType); result.Content.Headers.ContentDisposition = new System.Net.Http.Headers.ContentDispositionHeaderValue("attachment"); result.Content.Headers.ContentDisposition.FileName = (null != FileName ? FileName : Path.GetFileName(FilePath)); return result; } }}
这种方式虽然可以实现文件下载,但是下载速度实在太慢(在局域网中下载速度只有50K),稍大一点的文件就有可能导致客户端请求超时。
改为以下方式可实现高速下载的目的。在百兆局域网内实际测试可满速下载。
using System;using System.Collections;using System.Collections.Generic;using System.IO;using System.Linq;using System.Net;using System.Net.Http;using System.Runtime.Remoting.Contexts;using System.Text;using System.Threading.Tasks;using System.Web;using System.Web.Http;using System.Web.Http.Cors;using System.Net.Http.Headers;namespace Service.Controller{ public partial class APIController : ApiController { #region 辅助函数 public interface IWriteStreamToResponse<T> { T Suorce { get; set; } void WriteToStream(Stream outputStream, HttpContent content, TransportContext context); } public class StreamFromFileName : IWriteStreamToResponse<string> { private string _suorce; public string Suorce { get { return _suorce; } set { _suorce = value; } } public async void WriteToStream(Stream outputStream, HttpContent content, TransportContext context) { try { var buffer = new byte[1024 * 1024 * 2]; using (var video = File.Open(_suorce, FileMode.Open, FileAccess.Read, FileShare.Read)) { var length = (int)video.Length; var bytesRead = 1; while (length > 0 && bytesRead > 0) { bytesRead = video.Read(buffer, 0, Math.Min(length, buffer.Length)); await outputStream.WriteAsync(buffer, 0, bytesRead); length -= bytesRead; } } } catch (Exception ex) { return; } finally { outputStream.Close(); } } } public class StreamFromBytes : IWriteStreamToResponse<Stream> { private Stream _source; public Stream Suorce { get { return _source; } set { _source = value; } } public async void WriteToStream(Stream outputStream, HttpContent content, TransportContext context) { try { var buffer = new byte[1024 * 1024 * 2]; using (var video = _source) { var length = (int)video.Length; var bytesRead = 1; while (length > 0 && bytesRead > 0) { bytesRead = video.Read(buffer, 0, Math.Min(length, buffer.Length)); await outputStream.WriteAsync(buffer, 0, bytesRead); length -= bytesRead; } } } catch (Exception ex) { return; } finally { _source.Close(); outputStream.Close(); } } } #endregion public HttpResponseMessage GetFileResponse(string FilePath, string FileName = null, string ContentType = "application/octet-stream") { HttpResponseMessage response; IWriteStreamToResponse<string> ResponseStreamWriter; Action<Stream, HttpContent, TransportContext> sendMethod; ResponseStreamWriter = new StreamFromFileName() { Suorce = FilePath }; sendMethod = ResponseStreamWriter.WriteToStream; response = Request.CreateResponse(); response.Content = new System.Net.Http.PushStreamContent(sendMethod); response.Content.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue(ContentType); response.Content.Headers.ContentDisposition = new System.Net.Http.Headers.ContentDispositionHeaderValue("attachment"); response.Content.Headers.ContentDisposition.FileName = (null != FileName ? FileName : Path.GetFileName(FilePath)); return response; } }}
阅读全文
0 0
- .Net WebAPI 高速下载文件接口实现
- ios 实现高速下载文件原理
- .NET WebApi上传文件接口(带其他参数)
- WebApi 文件下载功能实例
- WebAPI文件上传与下载
- .net 实现文件下载
- nginx 高速处理文件下载
- Asp.net WebAPI 构建后台数据接口
- .net mvc4 Webapi Rest接口返回值
- ASP.NET WEBAPI实现微信JS-SDK接口注入权限验证配置
- springmvc实现webapi接口版本兼容
- WebAPI+NLog实现接口调用日志输出
- [WebApi] 捣鼓一个资源管理器--文件下载
- ASP.NET实现文件下载
- ASP.NET实现文件下载
- ASP.NET实现文件下载
- asp.net实现文件下载
- ASP.NET实现文件下载
- Java.io流的基本常用类
- 机器学习中的数据清洗与特征处理综述
- 手动实现jsonp
- 欢迎使用CSDN-markdown编辑器
- 我眼中的装饰器模式
- .Net WebAPI 高速下载文件接口实现
- arm交叉编译器gnueabi、none-eabi、arm-eabi、gnueabihf、gnueabi区别
- 结构体的4种初始化方式
- 在HashSet集合中添加三个Person对象,把姓名相同的人当做同一个人,禁止重复添加
- Cesium中Color类
- Revit开发IExternalCommandAvailability的使用
- lvm扩展硬盘空间大小
- c++ static问题详解
- java中的线程池技术及优化