Контроллер:Показано только загруженные изображения
[HttpPost]
public ActionResult UploadImage(List<HttpPostedFileBase> files)
{
EntityDBContext db = new EntityDBContext();
var imagesShown = db.Images.ToList();
foreach (var file in files)
{
if (file != null)
{
string imageName = Path.GetFileName(file.FileName);
string physicalPath = Server.MapPath("~/Images/" + imageName);
byte[] pictureAsBytes = new byte[file.ContentLength];
using (BinaryReader br = new BinaryReader(file.InputStream))
{
pictureAsBytes = br.ReadBytes(file.ContentLength);
}
//Save to folder
file.SaveAs(physicalPath);
//Save new record in database
Image img = new Image();
img.ImageName = imageName;
img.ImageBytes = pictureAsBytes;
db.Images.Add(img);
db.SaveChanges();
//Only show images that user uploaded, not entire database
imagesShown = imagesShown.Where(x => x.ImageName == imageName).ToList();
}
else
{
return View("Index");
}
}
return View("ShowImage", imagesShown);
}
Вид:
@model IEnumerable<Vidafo.Models.Image>
@foreach(var image in Model)
{
<img src="data:image; base64, @System.Convert.ToBase64String(image.ImageBytes)" />
}
Я попытался показать только пользователю изображения загрузили с IQueryable линии, однако это не хорошо, потому что, если имя уже в базе данных он будет размещать все из них.
Я хочу только фотографию пользователя, которую они только что загрузили для отображения. Не вся база данных, как мне это сделать? Я предполагаю, что мне нужно как-то использовать «файл», но я не уверен, как это сделать.
Спасибо так много. Я просто не мог это решить. Однако изображения не имеют функции .AddRange, поэтому вместо этого я помещаю это в цикл foreach. Это нормально? – sitBy
Уверенный, что это нормально. 'AddRange' доступен в EF 6, который я использую, поэтому вы должны использовать более старую версию. – Beyers