我将图像上传到具有byte []格式的表中。我的问题是,当我在视图上检索到该图像时,该图像将不会显示。
模型
{
public byte[] image {get; set;}
}
控制器
public async Task<IActionResult> Create(Profile profile, IFormFile image)
{
if (ModelState.IsValid)
{
using (var memoryStream = new MemoryStream())
{
image.CopyTo(memoryStream);
profile.image = memoryStream.ToArray();
}
_context.Add(image);
await _context.SaveChangesAsync();
return RedirectToAction(nameof(Index));
}
return View(image);
}
查看
<img src="@item.image" />
答案 0 :(得分:0)
您不能简单地将字节数组转储为HTML图像标签的源。它必须是URI。通常,这意味着您需要执行以下操作:从数据库检索图像数据并将其作为文件返回:
[HttpGet("profileimage")]
public async Task<IActionResult> GetProfileImage(int profileId)
{
var profile = _context.Profiles.FindAsync(profileId);
if (profile?.image == null) return NotFound();
return File(profile.image, "image/jpeg");
}
然后,您可以执行以下操作:
<img src="@Url.Action("GetProfileImage", new { profileId = item.Id })" />
或者,您可以使用数据URI。但是,这将导致整个图像数据包含在HTML文档中,从而增加了文档的总下载时间并延迟了渲染。此外,数据URI必须经过Base64编码,这实际上可以将图像大小增加大约1.5倍。对于小的,简单的图像,这没什么大不了的,但是对于较大的图像,您绝对应该避免这种方法。无论如何,这样做看起来像:
<img src="data:image/jpeg;base64,@Convert.ToBase64String(item.image)" />