FileContentResult 类
需求背景
跳过流程系统直接下载流程数据库的二进制文件。
定义
命名空间:Microsoft.AspNetCore.Mvc 程序集:Microsoft.AspNetCore.Mvc.Core.dll 包:Microsoft.AspNetCore.App.Ref v7.0.5
表示执行 ActionResult 时会将二进制文件写入响应的
代码语言:javascript
复制
public class FileContentResult : Microsoft.AspNetCore.Mvc.FileResult
继承Object->ActionResult->FileResult->FileContentResult
构造函数
FileContentResult(Byte[], MediaTypeHeaderValue) | 使用提供的 和contentType提供的 fileContents 创建一个新FileContentResult实例。 |
---|---|
FileContentResult(Byte[], String) | 使用提供的 和contentType提供的 fileContents 创建一个新FileContentResult实例。 |
实例:
代码语言:javascript
复制
/// <summary>
/// 下载流程上传的文件跳过流程系统直接下载
/// </summary>
/// <param name="affterOid">售后主键</param>
/// <param name="flieName">文件名称</param>
/// <returns></returns>
public FileContentResult FilePathDownload(string affterOid,string flieName)
{
try
{
HttpContext.Response.AppendHeader("Access-Control-Allow-Origin", "*");//支持跨域请求
string sql = "SELECT seqNO FROM dbo.*** WHERE Affter_EntryOID = '" + affterOid + "'";
string seqNO = "", ContentType ="";
byte[] buffer = null;
var re = erpReadService.GetDataTable(sql);
if (re.Rows.Count != 0)
{
seqNO = re.Rows[0]["seqNO"].ToString();
}
//Byte[] buffer = BlobStorage.DownloadFile(pathName);
string sqlH3 = "SELECT a.Content Content,a.ContentType ContentType FROM *** a LEFT JOIN *** b ON a.BizObjectId = b.BizObjectId WHERE b.SequenceNo = '" + seqNO + "' and a.FileName = '" + flieName + "'";
var resH3 = H3Service.GetDataTable(sqlH3);
if (re.Rows.Count != 0)
{
buffer = (byte[])resH3.Rows[0]["Content"];
ContentType = resH3.Rows[0]["ContentType"].ToString();
}
FileContentResult result = new FileContentResult(buffer, ContentType);
return result;
}
catch (Exception ex)
{
// log error
}
// how to handle if file is not found?
return new FileContentResult(new byte[] { }, "PDF");
}
补充 Controller 类提供File 方法:
- FilePathResult 直接将磁盘上的文件发送至浏览器
- FileContentResult 可以直接将 byte[] 以文件形式发送至浏览器(而不用创建临时文件)
- FileStreamResult 类 ActionResult 执行时会将文件从流写入响应的 FileStreamResult 的另一种用途是将其它网站上的文件作为本站文件下载(其实就是盗链)
其他方法详细的我看到过鹤冲天的博客介绍很详细:(致敬)https://www.cnblogs.com/ldp615/archive/2010/09/17/asp-net-mvc-file-result.html