Flash中使用Filereference上传文件的一些注意事项

FileReference用来上传文件,结合FileReferenceList使用,可以弹出一次文件选择框就上传很多个文件,比HTML form形式的友好很多。但是使用的时候,有些地方需要注意的:

  1. 上传文件时,不能增加自定义request header

    这点不同于URLLoader:URLLoader是可以增加自定义头部信息(request header)到对应的URLRequest对象中的,但是敏感的字段是不可以更改的,比如refer、cookie、host等等;而FileReferrence.upload使用的URLRequest,则不可以增加任何自定义头信息,所有自己添加的自定义header,都被播放器悄无声息地忽略掉了,没有任何报错和提示。如果一定要增加字段,只能添加到POST变量中。

  2. 只有在IE浏览器中, Filereference 才能附带浏览器Cookie信息

    这是一个很汗的bug,在非IE浏览器中,利用FileReference发出的HTTP请求,带的cookie资料都是IE的cookie。即便在Firefox或者chrome中,传送的cookie也是IE的!有的同学说这和默认浏览器设置有关,例如将默认浏览器设为Firefox,那么IE就得不到cookie。但是我测试了一下,发现无论默认浏览器是什么,发送的都是IE的cookie。解决方案暂时是借用JS得到cookie( ExternalInterface.call(”javascript:document.cookie”) ),当作变量post过去。服务器端也要做相应的调整,比较麻烦,针对非IE浏览器用非Cookie方式验证。

  3. Filereference 得不到文件的本地路径

    Flash10的Filereference可以得到本地文件的二进制文件 (存放在filereference.data)中,但是得不到文件路径(file://…)。这个问题还附带导致了一个问题,FilereferrenceList不能判断出重复选择的文件。就是说第一次弹出文件选择对话框的时候,用户选择了一个文件。过了一段时间再继续浏览文件,又选择了这个文件,这时候Flash是没有办法知道重复选择的。

  4. 不能设置上传的content-type

    给Filereference.upload 使用的URLRequest,是受一些安全性限制的,除了本身的一些关键字段不能修改之外,contnent-type属性也不能修改。可能会让人郁闷的是,这个也没有任何throw/warning报错。content-type的值恒定为 “ application/octet-stream ”。

  5. Filereference只支持实际存在的文件的上传下载

    要是要上传一些动态生成的数据到服务器存储,那就用不得Filereference,也看不到上传进度了。

内存里面的数据,希望上传到服务器保存为文件,可以用URLLoader,URLStream之类的代替。但是FlashPlayer10有个新增的安全性限制,当上传文件的时候,播放器会检查操作是否由用户点击触发。没有点击就上传,会被浏览器阻挡掉请求。播放器判断一个HTTP请求是否是文件上传的依据是form-based-HTML-file-upload规范,有两个标志:
是content-type含有“ multipart”,例如
multipart/form-data”,“mymultipartxxx”;
二是字段名
含有 filename
满足了这两点,flash播放器就会把这次请求当作文件上传处理,进而检查是否符合安全限制。要防止被阻挡掉也很简单,不要用filename这个关键字做数据的字段名即可。

你可能感兴趣的:(浏览器,header,IE,服务器,Flash,firefox)