【问题标题】:How to handle multiple image uploads如何处理多个图像上传
【发布时间】:2017-02-04 19:39:50
【问题描述】:

我正在开发一个 ASP.NET MVC 站点,该站点将允许用户将多个图像上传到画廊。在用户上传他们的图像之后,在将它们保存到数据库之前,用户将能够使用 jQuery 拖放重新排列图像。然后用户可以提交他们的上传。用户以后还可以编辑他们的画廊,并再次有能力重新调整他们的图像顺序。我不会将图像保存到数据库,只是文件名。我不确定如何最好地处理这个问题。我认为 POST 控制器将采用 List<HttpPostedFileBase> 参数,然后转换为 byte [] array 以保持图像顺序。然后将图像名称作为逗号分隔的字符串保存到数据库中?处理这种情况最有效的方法是什么?

【问题讨论】:

  • 重新分级逗号分隔为什么不将它存储为 json 所以字符串将是这样的: { "img1":"ImageName", "img2":"ImageName2"..etc} this将更容易访问特定图像并处理它(删除、编辑或添加)
  • 实际上我正在寻找的是处理图像文件并保存到数据库的最佳方法,基于图像顺序可能随时间变化的事实。
  • @Valkyriee,图像本身不会被保存到数据库,只有文件名。
  • 我应该在我的答案中添加您可以在数据库中添加一个字段以进行排序,任何时候您想将它加载到您的 jquery 并且它会处理它
  • 您需要 2 个表,一个用于您创建的“父”对象,一个用于与其关联的图像(一对多关系),该表将包含文件路径的属性,显示名称和父对象的 FK。如果你想以某种特定的顺序显示它们,那么它还需要一个属性(比如)int Order,以便你可以按Order 对它们进行排序。然后在你用来拖放/重新排列图像的任何插件中,你可以更新Order属性并保存回数据库。

标签: c# asp.net asp.net-mvc


【解决方案1】:

好的,所以如果我们拖放一侧,请将此视为您的视图:

@using (Html.BeginForm("Index", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
{
    <input type="file" name="files" value="" multiple="multiple"/>
    <input type="submit" value="Upload"/>
}

在您的控制器中:

[HttpPost]
public ActionResult Index(HttpPostedFileBase[] files)
{
    try
    {
        foreach (HttpPostedFileBase file in files)
        {
            string name = System.IO.Path.GetFileName(file.FileName);
            file.SaveAs(Server.MapPath("~/Images/" + name));

            string filename = "Images/" + name;

            //Save the the filename to your database
        }
    }
    catch
    {
        throw ex;
    }
    return View();
}

【讨论】:

  • 感谢您发布此信息。我基本上了解这部分内容,我试图了解的是跟踪图像顺序的最佳方法是什么。例如,用户上传了 4 张图片:pic1.jpg、pic2.jpg、pic3.jpg、pic4.jpg。然后将图像的顺序打乱为:pic4.jpg、pic1.jpg、pic 3.jpg、pic2.jpg。如何将图像名称写入数据库,以便当我从数据库读取并在视图中显示时,图像按照用户指定的正确顺序排列?
  • @PixelPaul 确实如此。 Stephen Muecke 所说的是最佳实践。
猜你喜欢
  • 2018-01-29
  • 2013-07-17
  • 1970-01-01
  • 2019-10-15
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-10-30
  • 2017-07-27
相关资源
最近更新 更多