我在我的MVC 3.0应用程序中使用'Uploadify'Jquery插件来上传多个文件。 它的工作正常,但显示上传失败的文件列表。通过'Uploadify'跟踪成功上传的文件名Jquery插件
如何跟踪成功上传的文件名?
我的脚本是这样的:
<link href="@Href("~/Content/uploadify.css")" rel="stylesheet" />
<script src="@Href("~/Scripts/jquery-1.4.1.js")" type="text/javascript"></script>
<script src="@Href("~/Scripts/jquery.uploadify.js")" type="text/javascript"></script>
<script type="text/javascript">
$(window).load(
function() {
$("#fileuploader").fileUpload({
'uploader': '/Scripts/uploader.swf',
'cancelImg': '/Images/cancel.png',
'buttonText': 'Select Image',
'script': 'Home/Upload',
'folder': '/uploads',
'fileDesc': 'Image & XML Files',
'fileExt': '*.jpg;*.jpeg;*.gif;*.png;*.xml',
'multi': true,
'auto': true
});
}
);
</script>
我的HTML代码:
<div id="fileuploader"></div>
<div>Upload Status</div>
Successful Files : <div> @TempData["SuccessfulFileList"]</div>
Failed Files :<div> @TempData["FailedFileList"]</div>
的控制器代码是这样的:
private static List<string> _successfulFileList = new List<string>();
private static List<string> _failedFileList = new List<string>();
public string Upload(HttpPostedFileBase fileData)
{
try
{
var fileName = this.Server.MapPath("~/uploads/" + System.IO.Path.GetFileName(fileData.FileName));
fileData.SaveAs(fileName);
_successfulFileList.Add(fileName);
}
catch
{
var failedFileName = fileData.FileName;
_failedFileList.Add(failedFileName);
}
TempData["SuccessfulFileList"] = _successfulFileList;
TempData["FailedFileList"] = _failedFileList;
return "Some Files Get uploaded";
}
到TempData是没有得到印在我的UI。 – Biki
你有没有调试过,看看'_successfulFileList'和'_failedFileList'实际包含了什么? – Jack
由于它们是静态的,我可以发现只有_successfulFileList被填充,但即使它们存储在tempdata中,它们也不会在我的cshtml中可见。 – Biki