Взятие изображения и сохранение его в виде строки от пользователя с помощью .net MVC 5 - PullRequest
0 голосов
/ 17 апреля 2019

Я являюсь студентом-разработчиком в .Net MVC 5 и хочу вставить изображение от нового пользователя в свою базу данных.Я нашел много методов для типа данных byte [], но, согласно моим исследованиям, нет источника для строкового типа данных (пример; Entity Framework 5 Код, сначала добавляющий изображение ).Что я могу сделать для строкового столбца ImageUrl в моей базе данных?Не могли бы вы помочь мне в этом вопросе?

Моя модель:

public class usersModel{
public string userImageUrl{get;set;}
}

Мой контроллер:

 public class UsersController : Controller
    {
        AgmEntities db = new AgmEntities();

        public ActionResult Create()
        {
            return View("Create", new usersModel());
        }

        [HttpPost]
        public ActionResult Create(usersModel uModel,HttpPostedFileBase file)
        {
            if (!ModelState.IsValid)
            {

                return View("Create");
            }

            var user = new Users();

            if(file !=null && file.ContentLength > 0)
            {
                string fileName = Path.GetFileName(file.FileName);
                string imgPath = Path.Combine(Server.MapPath("~/User_Images/"), fileName);
                file.SaveAs(imgPath);
            }
            user.userImageUrl = "~/User_Images/" + file.FileName;/*Error line*/
            db.Users.Add(user);
            db.SaveChanges();
            return RedirectToAction("Index", "Home");
        }
    }

Мой cshtml:

@using (Html.BeginForm()) 
{
    @Html.AntiForgeryToken()

        <div class="form-group">
            @Html.LabelFor(model => model.userImageUrl, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                <input type="file" name="ImageFile" />
                @Html.ValidationMessageFor(model => model.userImageUrl, "", new { @class = "text-danger" })
            </div>
        </div>
    }

1 Ответ

3 голосов
/ 17 апреля 2019

Вы должны добавить новый { enctype="multipart/form-data"} в форму, чтобы разрешить загрузку файла.

Html.BeginForm(
    null, null, FormMethod.Post, new { enctype="multipart/form-data"})

Измените код cshtml на:

@using (Html.BeginForm(
    null, null, FormMethod.Post, new { enctype="multipart/form-data"})) 
{
    @Html.AntiForgeryToken()

        <div class="form-group">
            @Html.LabelFor(model => model.userImageUrl, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                <input type="file" name="ImageFile" />
                @Html.ValidationMessageFor(model => model.userImageUrl, "", new { @class = "text-danger" })
            </div>
        </div>
    }

и переместите эту строку кода внутри if user.userImageUrl = "~/User_Images/" + file.FileName;/*Error line*/ в этом случае file.FileName может быть нулевым.

 if(file !=null && file.ContentLength > 0)
            {
                string fileName = Path.GetFileName(file.FileName);
                string imgPath = Path.Combine(Server.MapPath("~/User_Images/"), fileName);
                file.SaveAs(imgPath);
                user.userImageUrl = "~/User_Images/" + file.FileName;/*Error line*/
            }

Еще одно примечание, которое требует изменения parameter name в действии, аналогично name of input тип файла:

<input type="file" name="ImageFile" /> to <input type="file" name="file" /> 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...