gpt4 book ai didi

c# - ASP.Net MVC 5 图片上传到文件夹

转载 作者:数据小太阳 更新时间:2023-10-29 04:02:29 24 4
gpt4 key购买 nike

我有一个非常简单的 MVC5 应用程序,它有一个面向客户端的产品页面,我还使用了在 MVC 5 中构建的基本 CRUD 操作。

我有一个名为 Cakes.cs 的模型,因为客户销售蛋糕。很简单。这是该模型的代码:

    using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace TastyCakes.Models
{
public class Cakes
{
public int CakesID { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public decimal Price { get; set; }

public string CakeImage
{
get { return Name.Replace(" ", string.Empty) + ".jpg"; }
}
}
}

如您所见,我正在使用计算属性为每个蛋糕创建图像名称。每个蛋糕我只需要一张图片。现在,当我在我的 CRUD 页面上编辑蛋糕时。我想添加一个简单的图像上传来上传图像(不需要调整大小或缩略图)但我想强加计算的属性名称。换句话说:无论用户如何命名他们的照片,我的上传代码都会将其重命名为 Cakes.Name 的任何名称(减去任何空格)+".jpg",并将其保存到“~Images/Cakes”。

我只要求上传到实际的编辑页面,所以此时蛋糕已经创建好了。重命名文件所需的所有信息都应该在“编辑”页面上可用且易于使用。下面是我的编辑页面代码:

编辑页面:

@model TastyCakes.Models.Cakes

<div class="row">
<div class="large-12 columns">
<hgroup class="title">
<h1>Edit Cakes</h1>
</hgroup>

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

<div class="form-horizontal">
<hr />
@Html.ValidationSummary(true)
@Html.HiddenFor(model => model.CakesID)

<div class="medium-12 column">
@Html.LabelFor(model => model.Name)
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>

<div class="medium-12 column">
@Html.LabelFor(model => model.Description)
@Html.EditorFor(model => model.Description)
@Html.ValidationMessageFor(model => model.Description)
</div>

<div class="medium-12 column">
@Html.LabelFor(model => model.Price)
@Html.EditorFor(model => model.Price)
@Html.ValidationMessageFor(model => model.Price)
</div>

<div class="medium-12 column">
<input type="submit" value="Save" class="tiny button" />
@Html.ActionLink("Back to List", "Index", null, new { @class = "tiny button" })
</div>
</div>
}

@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
</div>
</div>

我已经回顾了一些 html5 和 ASP.Net 4 解决方案,但这太多了。我想要的很简单。任何想法或朝着正确方向的努力将不胜感激。我不仅将此代码用于客户网站,而且将其包含在用于教授非常基本的 MVC 概念的虚构网站中。

最佳答案

你需要:

  • file 类型的 input 添加到您的表单中,
  • 在你的表单元素上有属性 enctype = "multipart/form-data"

然后将 HttpPostedFileBase 添加到您的模型,其名称与 input 的名称相同。然后 HttpPostedFileModelBinder 将在调用操作之前从上传的文件填充模型属性。请注意,我认为您可能应该在某处添加模型 ID,也许作为路径元素,以保证图像路径中的唯一性,这样图像就不会意外被覆盖。

http://www.prideparrot.com/blog/archive/2012/8/uploading_and_returning_files 对此进行了相当完整的讨论。

public class Cakes
{
...

public HttpPostedFileBase UploadedFile { get; set; }

}

[HttpPost]
public ActionResult Edit(Cakes cake) // I'd probably use a view model here, not the domain model
{
if (ModelState.IsValid)
{
if (cakes.UploadedFile != null)
{
cakes.UploadedFile.SaveAs(Path.Combine("path-to-images-for-this-cake", cakes.CakeImage));
}

....
}
}

关于c# - ASP.Net MVC 5 图片上传到文件夹,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22623947/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com