如何将图像路径保存到数据库?MVC

本文关键字:数据库 MVC 保存 路径 图像 | 更新日期: 2023-09-27 18:20:55

我可以上传图片。但我并没有保存到数据库的路径。我该怎么做?

我删除了一些函数,认为代码更短。我希望大家都能理解。

我得到的是:

型号:

     public class Ogloszenie
    {
        [Key, ForeignKey("Pojazd")]
        public int PojazdOgloszenieId { get; set; }
        public RodzajPaliwa RodzajPaliwa { get; set; }
        public int RokProdukcji { get; set; }
        public int MocSilnika { get; set; }
        public int Przebieg { get; set; }
        public DateTime DataPrzegladu { get; set; }
        public DateTime DataUbezpieczenia { get; set; }
        public string OpisPojazdu { get; set; }
//path
        public string Zdjecie { get; set; }
//path
        public virtual Pojazd Pojazd { get; set; }
    }

控制器:

     [HttpPost]
            [ValidateAntiForgeryToken]
            public ActionResult Create([Bind(Include = "PojazdOgloszenieId,RodzajPaliwa,RokProdukcji,MocSilnika,Przebieg,DataPrzegladu,DataUbezpieczenia,OpisPojazdu,Zdjecie")] Ogloszenie ogloszenie, HttpPostedFileBase file)
            {
                if (ModelState.IsValid)
                {
                    if (file != null)
                    {
                        var fileName = Path.GetFileName(file.FileName);
                        var path = Path.Combine(Server.MapPath("~/Zdjecia/"), fileName);
                        file.SaveAs(path);
//*********************?????????? Something like this?     
Zdjecie = Url.Content("~/Zdjecia/" + file);
                    }
                    db.Ogloszenia.Add(ogloszenie);
                    db.SaveChanges();
                    return RedirectToAction("Index");
                }
                ViewBag.PojazdOgloszenieId = new SelectList(db.Pojazdy, "ID", "Marka", ogloszenie.PojazdOgloszenieId);
                return View(ogloszenie);
            }

视图:

    @model AutoMonit.Models.Ogloszenie
    <h2>Utwórz ogłoszenie</h2>
    @using (Html.BeginForm("Create", "Ogloszenie", FormMethod.Post, new { enctype = "multipart/form-data" }))
    {
        @Html.AntiForgeryToken()
        <div class="form-horizontal">
            <hr />
            @Html.ValidationSummary(true, "", new { @class = "text-danger" })
            <div class="form-group">
                @Html.LabelFor(model => model.PojazdOgloszenieId, "PojazdOgloszenieId", htmlAttributes: new { @class = "control-label col-md-2" })
                <div class="col-md-10">
                    @Html.DropDownListFor(model => model.PojazdOgloszenieId, null, htmlAttributes: new { @class = "form-control" })
                    @Html.ValidationMessageFor(model => model.PojazdOgloszenieId, "", new { @class = "text-danger" })
                </div>
            </div>
***************
.
.
.
***************
    //FILE UPLOADING
                <label for="file">Filename:</label>
                <input type="file" name="file" id="file" />

            <div class="form-group">
                <div class="col-md-offset-2 col-md-10">
                    <input type="submit" value="Utwórz" class="btn btn-default" />
                </div>
            </div>
        </div>
    }
    <div>
        @Html.ActionLink("Wróć", "Index")
    </div>

如何将图像路径保存到数据库?MVC

好的,我做到了(感谢codeRecap的灵感;)

    [HttpPost]
            [ValidateAntiForgeryToken]
            public ActionResult Create([Bind(Include = "PojazdOgloszenieId,RodzajPaliwa,RokProdukcji,MocSilnika,Przebieg,DataPrzegladu,DataUbezpieczenia,OpisPojazdu")] Ogloszenie ogloszenie, HttpPostedFileBase file)
            {
                if (ModelState.IsValid)
                {
                    if (file != null)
                    {
                        var fileName = Path.GetFileName(file.FileName);
                        var path = Path.Combine(Server.MapPath("~/Zdjecia/"), fileName);
                        file.SaveAs(path);
 ogloszenie.Zdjecie = Url.Content("~/Zdjecia/" + fileName);
                    }
                    db.Ogloszenia.Add(ogloszenie);
                    db.SaveChanges();
                    return RedirectToAction("Index");
                }
                ViewBag.PojazdOgloszenieId = new SelectList(db.Pojazdy, "ID", "Marka", ogloszenie.PojazdOgloszenieId);
                return View(ogloszenie);
            }