日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

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

發布時間:2024/8/1 php 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 uploadify 302 php,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': '<?php echo session_id();?>'},

'onComplete' : function(event, ID, fileObj, response, data) {

alert(response);

}

});

});

然后在服務器端session驗證之前:

if (isset($_POST['session'])){

session_id($_POST['session']);

session_start();//注意此函數要在session_id之后

}

當然,你也可以直接在url中將session id傳過去。

yii中代碼如下:

$('#<?php echo $upload_name_id;?>').uploadify({

'buttonText': '選擇文件..',

'fileObjName': 'imgFile',

'method': 'post',

'multi': false,

'queueID': 'fileQueue',

/*'uploadLimit': 2,*/

'fileTypeExts': '*.gif;*.png;*.jpg;*.bmp;*.jpeg;',

'buttonImage': '<?php echo $this->_static_public?>/js/uploadify/select.png',

'formData': {

'sessionId' : '<?php echo Yii::app()->session->sessionID; ?>',

'timestamp' : '<?php echo time();?>',

'token' : '<?php echo md5('unique_salt'.time()); ?>',

'modelName' : '<?php echo $modelName; ?>',

'modelId' : '<?php echo $model->id; ?>'

},

'swf': '<?php echo $this->_static_public;?>/js/uploadify/uploadify.swf',

'uploader': '<?php echo $this->createUrl('uploadify/basicExecute')?>',

'onUploadStart': function () {

$('#<?php echo $up_upload_name_id;?> img').remove();

$('#<?php echo $up_upload_name_id;?> a').remove();

$imgHtml = '';

$('#<?php echo $up_upload_name_id;?>').append($imgHtml);

},

'onUploadSuccess': function(file, data, response) {

$('.upload_load').remove();

var json = $.parseJSON(data);

if (json.state == 'success') {

$("#<?php echo $d_upload_name_id;?>").remove();

$(yt_upload_name_id).val(json.fileId);

$imgHtml ='

';

$imgHtml += '';

$imgHtml += '';

$imgHtml += '';

$imgHtml += '刪除';

$imgHtml +='

';

$('#<?php echo $up_upload_name_id;?>').append($imgHtml);

} else {

alert(json.message);

}

},

'onQueueComplete':function () {

$('.upload_load').remove();

}

});

服務端:

if (isset($_POST['sessionId'])) {

$session = Yii::app()->getSession();

$session->close();

$session->sessionID = $_POST['sessionId'];

$session->open();

}

ps:jquery上傳插件uploadify使用心得(總結)

自己使用實例:

1、jsp頁面:

//jquery文件上傳

$(document).ready(function()

{

$("#uploadify").uploadify({

'uploader': 'jsp/js/jquery_upload/uploadify.swf',

'script': 'uploadFile.svl',

'cancelImg': 'jsp/js/jquery_upload/cancel.png',

'queueID': 'fileQueue',

'auto': false,

'multi': true,

'method':'POST',

'scriptData':{'saveFolder':'stuPhotos'},//GET方式才可生效

'fileExt' :'*.jpg;*.gif;*.png', //控制可上傳文件的擴展名

'fileDesc': 'jpg、gif、png文件', //控制可上傳文件的擴展名描述,兩者需要同時使用

'buttonImg':'jsp/js/jquery_upload/selectBtn.gif',

'width':80,//"瀏覽"按鈕寬度

'onComplete':function(event,ID,fileObj,response,data){

//alert(response) //response為服務器響應數據

},

});

});

照片:

上傳|

取消上傳

2、服務端代碼

public class UploadFileUtil extends HttpServlet {

private static final long serialVersionUID = 1L;

File tmpDir = null;// 初始化上傳文件的臨時存放目錄

File saveDir = null;// 初始化上傳文件后的保存目錄

public UploadFileUtil() {

super();

}

protected void doGet(HttpServletRequest request,

HttpServletResponse response) throws ServletException, IOException {

doPost(request, response);

}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

try{

if(ServletFileUpload.isMultipartContent(request)){

response.setCharacterEncoding("utf-8");//務必,防止返回文件名是亂碼

DiskFileItemFactory dff = new DiskFileItemFactory();//創建該對象

dff.setRepository(tmpDir);//指定上傳文件的臨時目錄

dff.setSizeThreshold(1024000);//指定在內存中緩存數據大小,單位為byte

ServletFileUpload sfu = new ServletFileUpload(dff);//創建該對象

sfu.setFileSizeMax(5000000);//指定單個上傳文件的最大尺寸

sfu.setSizeMax(10000000);//指定一次上傳多個文件的總尺寸

FileItemIterator fii = sfu.getItemIterator(request);//解析request 請求,并返回FileItemIterator集合

while(fii.hasNext()){

FileItemStream fis = fii.next();//從集合中獲得一個文件流

if(!fis.isFormField() && fis.getName().length()>0){//過濾掉表單中非文件域

String fileName = fis.getName();//獲取文件名

String extName = "";

if (fileName.lastIndexOf(".") >= 0) {

extName = fileName.substring(fileName.lastIndexOf("."));

}

BufferedInputStream in = new BufferedInputStream(fis.openStream());//獲得文件輸入流

String uuidName = UUID.randomUUID().toString().replaceAll("-", "").toUpperCase();//用UUID生成文件名

BufferedOutputStream out = new BufferedOutputStream(new FileOutputStream(new File(saveDir+"/"+uuidName+extName)));//獲得文件輸出流

Streams.copy(in, out, true);//開始把文件寫到你指定的上傳文件夾

}

}

//jquery上傳方式返回

response.getWriter().print("upload success");//成功

}

}catch(Exception e){

response.getWriter().print("upload fail");//失敗

e.printStackTrace();

}

} public void init() throws ServletException {

super.init();

String serverPath = this.getServletConfig().getServletContext().getRealPath("/");//獲取服務器路徑

String tmpPath = serverPath+"/tmpUploadsFolder/";

String savePath = serverPath+"/uploadsFolder/";

tmpDir = new File(tmpPath);

saveDir = new File(savePath);

if(!tmpDir.isDirectory())

tmpDir.mkdir();

if(!saveDir.isDirectory())

saveDir.mkdir();

}}

以上內容是小編給大家介紹的jQuery Uploadify 上傳插件出現Http Error 302 錯誤的解決辦法,希望大家喜歡。

總結

以上是生活随笔為你收集整理的uploadify 302 php,jQuery Uploadify 上传插件出现Http Error 302 错误的解决办法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。