Hinzufügen von Bildern zum ASP.net-Kern

Ich wollte ein Bild als Teil der Modellklasse hinzufügen und es in der Indexansicht anzeigen. Ich habe Probleme, das Bild entweder als Byte [] oder als iFormFile zu klassifizieren.

Das ist, was ich versuche zu erreichen

Erstelle eine Seite, um eine Liste von Mitarbeitern einzufügen

Auf der Indexseite können Sie die Mitarbeiter auflisten und auch deren Bilder anzeigen.

Hier ist das Modell.

Employee.cs

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Http;

namespace MvcMovie.Models
{
  pu,blic class Employee
  {
    public int ID { get; set; }
    [Required]
    public string FirstName { get; set; }
    [Required]
    public string LastName { get; set; }
    [Required]
    public string Nationality { get; set; }
    [Required]
    public string NRIC { get; set; }
    [Required]
    public string StaffID { get; set; }
    [Required]
    public int AccessRights { get; set; }
    [Required]
    public DateTime DOB { get; set; }

    [Required(ErrorMessage = "Please Upload a Valid Image File. Only jpg format allowed")]
    [DataType(DataType.Upload)]
    [Display(Name = "Upload Product Image")]
    [FileExtensions(Extensions = "jpg")]
    public IFormFile Image { get; set; }

    public string ImageName { get; set; }
  }
}

Dies ist der Codeabschnitt des Controllers, der den Fehler generiert.

EmployeeController.cs

[HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<IActionResult> Create(Employee employee, IFormFile    Image) 
    {
        if (ModelState.IsValid)
        {

            if (Image != null && Image.Length > 0)
            {

                var file = Image;
                var uploads = Path.Combine(_environment.WebRootPath, "uploads\\img\\employees");

                if (file.Length > 0)
                {
                    var fileName = ContentDispositionHeaderValue.Parse
                        (file.ContentDisposition).FileName.Trim('"');

                    System.Console.WriteLine(fileName);
                    using (var fileStream = new FileStream(Path.Combine(uploads, file.FileName), FileMode.Create))
                    {
                        await file.CopyToAsync(fileStream);
                        employee.ImageName = Path.Combine(uploads, file.FileName);
                    }

                    var imageUrl = Path.Combine(uploads + file.FileName);

                }
            }

            _context.Add(employee);
            await _context.SaveChangesAsync();
            return RedirectToAction("Index");

        }
        else
        {
            var errors = ModelState.Values.SelectMany(v => v.Errors);
        }
        return View(employee);
    }

Create.cshtml

<form asp-action="Create" enctype="multipart/form-data" asp-antiforgery="true"  method="post">
 <div>
      ...

      <div class="form-group">
          <label asp-for="Image" class="control-label col-md-2"></label>
          <div class="col-md-10">
               <input asp-for="Image" class="form-control" />
               <span  class="text-danger"></span>
          </div>
      </div>
      <div class="form-group">
          <div class="col-md-offset-2 col-md-10">
          <input type="submit" value="Create" class="btn btn-default" />
      </div>
  </div>
</form>

Ich habe es geschafft, das Bild in den richtigen Ordner hochzuladen. Ich habe jedoch ein Problem mit der Anweisung "_context.Add (employee)". Dort steht, dass ich kein iformfile hinzufügen konnte. Ich habe kein Problem mit den anderen Feldern.

Ich habe versucht, Employee.Image in ein Byte-Array zu ändern. Ich bin jedoch nicht sicher, wie ich meine Ansicht strukturieren soll, um diese Informationen an die Funktion create zu übergeben.

Antworten auf die Frage(2)

Ihre Antwort auf die Frage