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

前端之家收集整理的这篇文章主要介绍了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的值传到服务端:

$(document).ready(function() { $('#file_upload').uploadify({ 'uploader' : 'uploadify/uploadify.swf','script' : 'uploadify.PHP','folder' : 'uploads/file','formData': { 'session': ''},'onComplete' : function(event,ID,fileObj,response,data) { alert(response); } }); });

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

函数要在session_id之后 }

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

yii中代码如下:

').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页面

猜你在找的jQuery相关文章