在Asp.net Mvc 3中使用swfupload

时间:2022-08-29 08:37:19

 

一、无法在iis下显示上传按钮的问题

注意在js中,路径要绝对按照下面的方式书写:

flash_url: '@Url.Content("~/Common/SwfUpload/swfupload.swf")',

button_image_url: '@Url.Content("~/Common/SwfUpload/TestImageNoText_65x29.png")',

 

如果写成

button_image_url: '/Common/SwfUpload/TestImageNoText_65x29.png")',

则在iisexpress中调试能够通过,但在iis中运行的时候会出现错误,原因是前者会将虚拟路径加上,后者不会。

最终造成的问题是:1、上传按钮不会显示;2、当然也无法点击打开文件对话框,因为swf文件也无法载入。

 

二、上传路径的写法:

假设我们使用UploadController的Upload方法,来处理上传,那么:

1、参数要一致,当然,我们可以不要设置参数,只用Request.Files来获得传来的文件

2、路径和flash_url一致,也用url.Content,当然也可用Url.Action

 

三、后台代码的书写:

对于1个文件,对于多个文件

 

四、文件大小限制

 

五、file和swfupload的区别:

原理上说,swfupload在本地读取文件,我们通过js能够获取本地的进度。因此,开始传了多少,在尚未到达服务器的时候我们就知道。

file控件则是整个文件传递到服务器后我们才能知道进度,当然,有一些特别的服务端的方法,可以解析请求内容,得到“到达的数量”

 

因此,swfupload通过js轮询本地的进度。

当然,如果服务端处理耗时较长的话,也可以由本地js,轮询服务端某个进度值。

所以,可以统一进度条的样式,服务端处理通常包括:1、将到达的请求(已经包含整个文件)保存到磁盘上;2、如果是导入操作,再将其加入数据库。

这是对excel之类的情形,如果以某种文件形式上传导入到数据库,则无需保存文件的操作,仅针对stream处理即可。

 

六、考虑客户端禁用java或未安装Flash的问题

 

七、封装上传功能:

   实际上,对于单文件上传,理想的方法是提供一个按钮,选择文件后,在按钮后方或者下方,出现文件名,正在上传和一个进度条。当然,能够显示上传耗时、剩余多少时间、上传速度最好。

上传结束后,保持这些信息,同时显示“上传成功”,下次选择文件的时候,重复此动作。

   如果客户端禁用js,则改用file控件,不显示进度---此时也无法通过js做什么。

   如果客户端可用js,但未安装flash,这时可以用一个滚动的gif图形,粗略的表示上传正在进行。

 

  对于多文件,方式差不多。大体上,swfupload官网的Demo包括file队列、速度等js文件,改改就能用。

 

   对于Asp.net mvc,实际上可以有两种封装方法:

1、封装为htmlhelper

2、全局提供唯一的一个上传Action,各处调用。