使用ASP.NET MVC 3中的Jquery File Upload上载文件

时间:2013-02-26 19:53:33

标签: asp.net-mvc-3 jquery jquery-forms-plugin

有没有人有一个干净的建议来实例化这个jquery的有用库。

我需要提交文件并管理来自服务器的 Json 响应。 我总是在 Js 代码中得不到任何json响应。我已经回顾了一些提到它的文章,但代码不符合目的。 情况是:我实现了submition并保存在数据库中,但Json响应永远不会到达。

提前致谢。

这是我的观看代码:

<script type="text/javascript">

$("#formUplImg").fileupload({
    dataType: "json",
    url:'@Url.Action("CreateJson","ProductImage")',
    done: function (e, data) {
        alert(data.StatusMessage);
    }
});

</script>



@using (Html.BeginForm("CreateJson", "ProductImage", FormMethod.Post, new { id = "formUplImg", enctype = "multipart/form-data", @class = "jqtransform" }))
{
@Html.ValidationSummary(true)

<div class="rowElem">
    <input type="file" id="Content" name="Content" />
</div>
<div class="rowElem">
    @Html.ValidationMessageFor(item => item.Content)
</div>

<div class="rowElem">@Html.JQueryUI().Button("Guardar imagen", ButtonElement.Button, ButtonType.Submit, new { id = "guardar_imagen" })</div>
}

这是我的控制器操作代码:

  [HttpPost]
    public ContentResult CreateJson(UploadedFileInfo fileInfo)
    {
        try
        {
            if (fileInfo.Content == null)
                throw new Exception("Hubo problemas con el envío. Seleccione un archivo a subir");

            var file = new TempDocument
            {
                CreatedBy = User.Identity.Name,
                CreationTime = DateTime.Now,
                FileName = fileInfo.Content.FileName,
                MimeType = fileInfo.Content.ContentType,
                Size = fileInfo.Content.ContentLength,
                Content = new byte[fileInfo.Content.ContentLength]//Image content to save
            };

            fileInfo.Content.InputStream.Read(file.Content, 0, fileInfo.Content.ContentLength);//Reading image content into ProductImage object
            DocumentsManager.StorePendingDocuments.Add(file);
            DocumentsManager.SaveTempDocuments();//Store each document uploaded to: TempDocument Table

            TempData["SuccessMsg"] = "The image was saved successfully";

            var json = new JavaScriptSerializer().Serialize(new { Success = true, StatusMessage = "El objeto fue insertado correctamente" });
            return Content(json, "application/json");
        }
        catch (Exception exception)
        {
            TempData["ErrorMsg"] = exception.Message;
            var json = new JavaScriptSerializer().Serialize(new { Success = false, StatusMessage = exception.Message });
            return Content(json, "application/json");
        }
    }

1 个答案:

答案 0 :(得分:-1)

使用Action的返回类型作为ActionResult并使用:

`return Json(new { Result = "Success" });`

因此,在成功时,您将获得包含结果值的Json对象。