swfupload 上传时候火狐下cookie 为空Bug

来源:互联网 发布:小满软件 编辑:程序博客网 时间:2024/05/17 00:04


使用SWFUpload的时候一定要小心cookie bug:在非IE内核内核的浏览器下使用SWFUpload上传文件时,该请求会忽略自身浏览器中的所有cookie只会将IE浏览器下的属于该域的持久cookie(persistent cookies)发送到服务端,非持久cookie( Session only)不会被发送。遗憾的是此Bug并非是SWFUpload内部实现的问题(所有的Flash上传都会存在此bug),而是FlashPlayer的bug,所有使用FileReference类上传文件时会存在此问题。幸运的是我们有办法绕开此陷阱。

  假设一种使用场景,用户登录系统以后,我们会在cookie中写入一个非持久的key值来判断用户身份。当用户使用SWFUpload上传文件的时候,服务端程序通过Requeset中的cookie来判断用户身份。在IE下我们的功能正常,但在FF下你会发现服务端脚本从Request中取到的cookie是空的,这就是很多人遇到的cookie丢失。前面我也提到了非IE内核的浏览器忽略了自身的所有cookie。

  假如用户同时在IE下登录了另外一个账号,并且选择了记住账号,那么我们的程序逻辑可能会写入一个持久的key值。然后用户在FF下上传照片,服务端是接受到cookie中的key值了,但遗憾的是此key是IE下登录账号的cookie,一不小心这就造成了用户身份判断错误的bug,A用户传了张照片居然是属于B用户的。

  解决方法:

  幸运的是AS3提供的URLRequest对象来包装客户端请求,我们可以上传文件的同时,给请求添加POST值对。因此当我们的上传程序需要依赖客户端cookie的时候,我们可以在上传开始前使用JS将我们需要的cookie读取出来,然后使用SWFUpload提供的addPostParam方法添加到POST中去,服务端从POST中接受所需要的"cookie"值即可,不再依赖Request中的cookie机制

   function <%= this.GetControlId("load") %>() {        var LoadSettings = {            upload_url:"UpLoadRes.aspx?NodeID=<%=nodeid%>",            post_params:{                            ASPSESSID: "<%=Session.SessionID %>",                            AUTHID : "<%=Request.Cookies[FormsAuthentication.FormsCookieName].Value%>",                    path: "<%=swfUploadInfo.Path%>",                    fn:"<%=swfUploadInfo.OldFileName%>",                            uid:<%=UserID%> //Cookie的值,在后台中写出其值,传递到服务器中,在服务器中使用Form.Request["uid"]获得


————————————————————————————————————————————————

SILVER 注: 或者直接用  core/plugins/swfupload.cookies.js 插件,这个插件会自动遍历当前域下的所有 cookies 并自动 addPostParam 到swf里同时会回传到 upload.php 目标处理程序里, 比如现在有 $_COOKIE['silver'] 那么在 upload 里就直接 $_POST['silver'] 便可以获得了,自己再存一遍cookie。


原创粉丝点击