微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jQuery Uploadify 上传插件出现Http Error 302 错误的解决办法

前段时间介绍过jquery uploadify上传插件的使用方法,我在使用中遇到过Http Error 302错误问题,应该会有很多人在使用中遇到过,在此记录下来:

首先http 302是请求被重定向的意思,这就很容易理解了,如果你的uploadify处理上传脚本有session验证,就会出现此错误,因为flash在执行post请求的时候没有包含cookie信息,而服务器的session会根据客户端的cookie来得到SESSIONID。没有提交cookie自然就不能获取到session,然后uploadify就返回了302(请求被重定向)的错误

解决办法当然是把session_id的值传到服务端:

rush:js;">

然后在服务器端session验证之前:

rush:js;"> if (isset($_POST['session'])){ session_id($_POST['session']); session_start();//注意此函数要在session_id之后 }

当然,你也可以直接在url中将session id传过去。

yii中代码如下:

rush:js;"> $('#').uploadify({ 'buttonText': '选择文件..','fileObjName': 'imgFile','method': 'post','multi': false,'queueID': 'fileQueue',/*'uploadLimit': 2,*/ 'fileTypeExts': '*.gif;*.png;*.jpg;*.bmp;*.jpeg;','buttonImage': '_static_public?>/js/uploadify/select.png','formData': { 'sessionId' : 'session->sessionID; ?>','timestamp' : '','token' : '','modelName' : '','modelId' : 'id; ?>' },'swf': '_static_public;?>/js/uploadify/uploadify.swf','uploader': 'createUrl('uploadify/basicExecute')?>','onUploadStart': function () { $('# img').remove(); $('# a').remove(); $imgHtml = ''; $('#').append($imgHtml); },'onUploadSuccess': function(file,data,response) { $('.upload_load').remove(); var json = $.parseJSON(data); if (json.state == 'success') { $("#").remove(); $(yt_upload_name_id).val(json.fileId); $imgHtml ='
","")">删除'; $imgHtml +='
'; $('#').append($imgHtml); } else { alert(json.message); } },'onQueueComplete':function () { $('.upload_load').remove(); } });

服务端:

getSession(); $session->close(); $session->sessionID = $_POST['sessionId']; $session->open(); }

ps:jquery上传插件uploadify使用心得(总结)

自己使用实例:

1、jsp页面

rush:js;">

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐