繁体   English   中英

从ASP.NET MVC3中DB中没有的byte []渲染图像

[英]Render image from byte[] that is not in the DB in ASP.NET MVC3

这是在这里多次提出的一个问题的变体。 一个示例: 使用ASP.Net MVC3显示byte []中包含的图像 问题是如何从字节数组渲染图像。

在所有这些问题中,都有一个类似于我在上面提供的链接中的答案之一的“操作”:

public FileContentResult Display(string id) {   
byte[] byteArray = GetImageFromDB(id);   
return new FileContentResult(byteArray, "image/jpeg");
}

使用类似于此的图像标签:

<img src="@Url.Action("Display", new { id = Model.Id })" />

这样做是因为不可能通过GET请求发送字节数组,因此仅发送ID即可在Action方法中进行查找。 我得到了这一部分,这不是问题。 我想做的是创建一个“预览”页面,他们可以在保存数据库之前检查其工作。 他们可以查看“标题”,“文本”和“图像”的布局,并决定是否保存,或者返回并编辑更多内容。 因此,“ GetImageFromDB(id)”部分将不起作用,因为该对象尚未保存到数据库中。

有什么方法可以做到这一点,还是我只需要在数据库中临时保存字节数组并以这种方式访问​​“预览”页面?

如果要稍后显示上传的文件(作为预览或全尺寸图像),则需要将上传的文件存储在服务器上的某个位置。 无论是数据库还是文件系统,都取决于您。 因此,一旦文件上载,您可以使用一些唯一的Guid重命名该文件,并将其作为临时文件存储在服务器上的某个位置,然后将该Guid返回给客户端,以便它可以创建指向通过Guid的预览控制器操作的操作链接它将从临时位置获取文件并将其流式传输到客户端。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM