Diskuze: ASP.NET MVC 5 Obrázek z SQL Databáze
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Nevím, jak se toto má dělat správně, ale já jsem do databáze ukládal pouze název obrázku a cestu k němu, případně nějakou vazbu na nějakou osobu (která k tomu obrázku patří) a obrázky samotné jsem měl vždycky uložené v nějaké složce. Při výpisu jsem se pouze odkazoval do konkrétní složky podle výběru konkrétní položky z DB.
Napiš si k modelu (nebo ViewModelu) další vlastnost, který ti inicializuje.
private Image image;
public Image Image
{
get
{
if(image == null)
{
MemoryStream ms = new MemoryStream(array);
image = Image.FromStream(ms);
}
return image;
}
}
Napsal jsem medotu:
public Image GetImg(byte[] imgStream)
{
MemoryStream ms = new MemoryStream(imgStream);
Image = Image.FromStream(ms);
return Image;
}
Následně v Index.cshtml:
<td>
@{
CDWA.Models.GetImage getImage = new CDWA.Models.GetImage();
var moje = getImage.GetImg(item.Picture);
}
<img src="@moje" alt="Image" />
</td>
Nefunguje ti to, protože do atributu src neukládáš URL obrázku.
Lepší způsob je uložit si obrázek na server a vrátit si jeho URL, kterou
uložíš do databáze s názvem obrázku atd. Potom si ji jednoduše vytáhneš
a naplníš s ním atribut src
Sorry, tak jsem googlil trošku dále než na první odkaz zkus tohle:
public byte[] Image {get;set;}
private string imagePath;
public string ImagePath
{
get
{
if(imagePath == null && Image != null)
{
imagePath = "data:image/png;base64," + Convert.ToBase64String(Image, 0, Image.Length);
}
return imagePath;
}
}
Nakonec jsem to vyřešil takto. Díky všem za tipy a rady
<td>
<img src="data:image/jpg;base64,@Convert.ToBase64String(item.Picture,0,item.Picture.Length ,
Base64FormattingOptions.None)"
alt="Image" width="100" height="100" />
</td>
Zobrazeno 8 zpráv z 8.