Классы данных EF core `
public class Manga
{
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public DateTime? DateCreated { get; set; }
public DateTime? Updated { get; set; }
public byte[] Image { get; set; }
//Manga can have many chapters
public ICollection<Chapter> Chapters { get; set; }
}
public class Chapter
{
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public DateTime? DateCreated { get; set; }
public DateTime? Updated { get; set; }
public byte[] Image { get; set; }
//Chapter can only have manga
public Manga Manga { get; set; }
//The chapter connected to the manga
public int MangaId { get; set; }
}
` Я пытаюсь научиться загружать изображения и файлы. Правильное изображение является приоритетом. Я хочу разрешить пользователям загружать изображения и использоваться публично. Я использую метод двоичного массива. Это плохая идея? Что будет лучше, если это не пойдет?
При работе над этим я получаю ошибку модели:
Значение 'narutotest.jpg' недопустимо для изображения
Мой код:
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<IActionResult> Create([Bind("Id,Name,Description,Image")] Manga manga, List<IFormFile> Image)
{
if (ModelState.IsValid)
{
foreach (var item in Image)
{
if(item.Length > 0)
{
using (var stream = new MemoryStream())
{
await item.CopyToAsync(stream);
manga.Image = stream.ToArray();
}
}
}
manga.DateCreated = DateTime.Now;
manga.Updated = DateTime.Now;
_context.Add(manga);
await _context.SaveChangesAsync();
return RedirectToAction(nameof(Index));
}
return View(manga);
}
Вид:
<div class="row">
<div class="col-md-4">
<form asp-action="Create">
<div asp-validation-summary="ModelOnly" class="text-danger"></div>
<div class="form-group">
<label asp-for="Name" class="control-label"></label>
<input asp-for="Name" class="form-control" />
<span asp-validation-for="Name" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Description" class="control-label"></label>
<input asp-for="Description" class="form-control" />
<span asp-validation-for="Description" class="text-danger"></span>
</div>
<div class="form-group">
<label asp-for="Image" class="control-label"></label>
<input asp-for="Image" type="file" id="files" />
<span asp-validation-for="Image" class="text-danger"></span>
</div>
<div class="form-group">
<input type="submit" value="Create" class="btn btn-primary" />
</div>
</form>
</div>
</div>