我在我的MVC 3.0应用程序中使用'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>
Controller代码如下:
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";
}
答案 0 :(得分:0)
您正在使用Flash组件上传文件(Uploadify
)。 Flash组件不发送cookie。会话由cookie跟踪。 TempData使用Session。结论=&gt;您不能将TempData与Flash客户端一起使用。有some ugly workarounds。
据说在控制器中使用静态列表来存储上传的文件是非常危险的,因为List<T>
对象不是线程安全的,如果你有2个用户并行上传文件,你的应用程序可能会崩溃。
作为替代方案,您可以将上传文件的列表存储到数据存储区(数据库或其他内容),然后从那里获取,而不是依赖会话。
答案 1 :(得分:0)
我在这里找到了一个非常具有描述性的解释:Link
参考:http://blog.bobcravens.com/2010/02/upload-files-with-progress-using-uploadify/