如何将二进制数据转换为图片显示在Div标签或img标签中?

how to convert binary data to image and display in Div Tag or img Tag?

我正在将我的图像转换为二进制数据并以二进制格式存储:

byte[] bytes = System.IO.File.ReadAllBytes(@"F:\Image\Img1.jpg");

我存储图像的数据库字段是:Varbinary(Max)

现在我正在从我的数据库中读取这个二进制数据并且我正在获取二进制数据。

我想在此 Div 标签中显示图像。

这是我的观点:

 <div class="Image-ad"></div>

我的Class:

 public class ImageAdd   
 {
        public Guid ImageAddId { get; set; }
        public byte[] Image { get; set; }
 }

我的控制器:

public ActionResult Index()
{
   var data=db.ImageAdd.ToList();    
   return View(db);
}

如何将此二进制数据转换为图像并显示在 Div 标签中???

两个选项:

1 : 将此添加到图像 div

<img src="data:image;base64,@System.Convert.ToBase64String(Model.Image)" />

大功告成!

2: 另一种方法是向您的控制器添加一个简单的方法,并在您的视图中调用它来显示图像标签。 将此方法添加到您的控制器:

public ActionResult GetImage(byte[] data) 
{
  MemoryStream ms = new MemoryStream(data)
  return File(ms.ToArray(), "image/png");
}

并在视图中将此行添加到图像 div:

<img src="@Url.Action("GetImage", "MyController", new { data = Model.Image })" />

您还可以使用 canvas 标签将图像加载到其中并以这种方式呈现,我们这样做是为了在最近的项目中预览上传的图像。