2015-06-25 2 views
0

Контроллер:Показано только загруженные изображения

[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 линии, однако это не хорошо, потому что, если имя уже в базе данных он будет размещать все из них.

Я хочу только фотографию пользователя, которую они только что загрузили для отображения. Не вся база данных, как мне это сделать? Я предполагаю, что мне нужно как-то использовать «файл», но я не уверен, как это сделать.

ответ

1

следующие результаты сниппет в только один сохранить и возвращает только недавно загруженные изображения (я не проверял код загрузки файла, поэтому при условии, что правильно работает):

[HttpPost] 
public ActionResult UploadImage(List<HttpPostedFileBase> files) 
{ 
    EntityDBContext db = new EntityDBContext(); 
    List<Image> uploadedImages = new List<Image>(); 

    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 
       { 
        ImageName = imageName; 
        ImageBytes = pictureAsBytes; 
       }; 

      uploadedImages.Add(img); 
     } 
    } 
    db.Images.AddRange(uploadedImages); 
    db.SaveChanges(); 
    return View("ShowImage", uploadedImages); 
} 
+0

Спасибо так много. Я просто не мог это решить. Однако изображения не имеют функции .AddRange, поэтому вместо этого я помещаю это в цикл foreach. Это нормально? – sitBy

+0

Уверенный, что это нормально. 'AddRange' доступен в EF 6, который я использую, поэтому вы должны использовать более старую версию. – Beyers

Смежные вопросы