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

标签 c# javascript forms asp.net-mvc-5 image-uploading

我有一个非常简单的 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/

相关文章:

jquery - 如何显示很长的选择选项的所有文本?

php - 访问 $_POST 时出现未定义索引错误

c# - 用于从文本文件中读取意大利语字符的正确编码

c# - 使用c#将csv文件插入MYSQL表

c# - 使用 LINQ 从两个列表中获取所有可能的连接对

javascript - 动态插入内容的空白消失

c# - 执行命令和 Now()

javascript - 在 Ember-data 中以自定义方式保存属性

javascript - 用正则表达式替换 URL 中的参数

forms - 以 angular2 模型驱动形式重用组件