jQuery Ajax文件上傳(php)
如何實現(xiàn)jQuery的Ajax文件上傳,PHP如實文件上傳.
AJAX上傳文件,PHP上傳文件。
【PHP文件上傳】
在開始之前,我覺得是有必要把通WEB上傳文件的原理簡單說一下的。
實際上,在這里不管是PHP,JSP,還是ASP處理上傳的文件,其實都是WEB早已把文件上傳到服務器了,我們只是運用上傳處理函數(shù)來處理上傳的文件。
而處理函數(shù)一般都是用PHP,JSP,ASP等服務端語言來實現(xiàn)的。那么如何通過WEB(HTTP協(xié)議來上傳文件呢?)你需要類似于以下的HTML代碼:
test.html
<form action="do_file_upload.php" method="post" enctype="multipart/form-data">
<p>Pictures:
<input type="file" name="picture" />
<input type="submit" value="Send" />
</p>
</form>
注意:enctype="multipart/form-data",是必需的,它告訴FORM表這個是一文件上傳類型,一旦這次請求成功后,文件就被上傳到了服務器的臨時文件夾中,
至于到達目的地后,文件將會被怎么樣處理那就是PHP,JSP,ASP的事了。
(不過,你不要高興的太早,如果該文件沒有被移動到其它地方也沒有被改名,則該文件將在表單請求結束時被刪除。所以我們要寫一個處理上傳文件的腳本)
這里我們用PHP來處理
do_file_upload.php
<?php
$error = ""; //上傳文件出錯信息
$msg = "";
$fileElementName = 'picture';
$allowType = array(".jpg",".gif",".png"); //允許上傳的文件類型
$num = strrpos($_FILES['picture']['name'] ,'.');
$fileSuffixName = substr($_FILES['picture']['name'],$num,8);//此數(shù)可變
$fileSuffixName = strtolower($fileSuffixName); //確定上傳文件的類型
$upFilePath = 'd:/'; //最終存放路徑
if(!empty($_FILES[$fileElementName]['error']))
{
switch($_FILES[$fileElementName]['error'])
{
case '1':
$error = '傳的文件超過了 php.ini 中 upload_max_filesize 選項限制的值';
break;
case '2':
$error = '上傳文件的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值';
break;
case '3':
$error = '文件只有部分被上傳';
break;
case '4':
$error = '沒有文件被上傳';
break;
case '6':
$error = '找不到臨時文件夾';
break;
case '7':
$error = '文件寫入失敗';
break;
default:
$error = '未知錯誤';
}
}elseif(empty($_FILES['fileToUpload']['tmp_name']) || $_FILES['fileToUpload']['tmp_name'] == 'none')
{
$error = '沒有上傳文件.';
}else if(!in_array($fileSuffixName,$allowType))
{
$error = '不允許上傳的文件類型';
}else{
);
if($ok === FALSE){
$error = '上傳失敗';
}
}
?>
另注:關于$_FILES數(shù)組
此數(shù)組包含有所有上傳的文件信息,即記錄下了上傳文件時的相關信息。
以上范例中 $_FILES 數(shù)組的內容如下所示。我們假設文件上傳字段的名稱如上例所示,為 userfile。名稱可隨意命名。
$_FILES['userfile']['name']
客戶端機器文件的原名稱。
$_FILES['userfile']['type']
文件的 MIME 類型,如果瀏覽器提供此信息的話。一個例子是“image/gif”。不過此 MIME 類型在 PHP 端并不檢查,因此不要想當然認為有這個值。
$_FILES['userfile']['size']
已上傳文件的大小,單位為字節(jié)。
$_FILES['userfile']['tmp_name']
文件被上傳后在服務端儲存的臨時文件名。
$_FILES['userfile']['error']
和該文件上傳相關的錯誤代碼。此項目是在 PHP 4.2.0 版本中增加的。
【AJAX文件上傳】
其實就是實現(xiàn)無刷新式的文件上傳??刹捎肐FRAME文件上傳原理。
實際上在用PHP上傳文件時。。。只能用$_FILES形式,但是若我們只是單一的用JS方式取其ID,如<input id='img' type='file'>..document.getElementById('img').value或者jquery形式的$("#img")都是不能正真實際上傳的(但是還是有很多人這樣做,剛開始時我也是)。
可是功能上又要要求實現(xiàn)所謂的“異步上傳”,怎么辦呢??只能借助于第三方的組件,或者自己寫一個(在網(wǎng)頁里嵌入一個IFRAME)。但如果是考慮開發(fā)時間,那以用第三方的,這里有一個不錯的jQuery的Ajax文件上傳的組件,是“ajaxfileupload.js",其組件下載地址為:http://www.phpletter.com/,下載完畢里面有一個php的應用demo,很容易看懂的。
過程:
(1 )前端上文件的代碼: test.php
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="ajaxfileupload.js"></script>
<script type="text/javascript">
function ajaxFileUpload()
{
$.ajaxFileUpload
(
{
url:'doajaxfileupload.php', //你處理上傳文件的服務端
secureuri:false,
fileElementId:'img',
dataType: 'json',
success: function (data)
{
alert(data.file_infor);
}
}
)
return false;
}
</script>
相應的HTML為:
<input id="img" type="file" size="45" name="img" class="input">
<button class="button" id="buttonUpload" onclick="return ajaxFileUpload();">Upload</button>
這樣客戶端就完成了。
(2) 再服務器端時 doajaxfileupload.php
此處為了簡便的檢測是否真正的傳值過來了,你可以將它存起來了。
$file_infor = var_export($_FILES,true);
file_put_contents("d:file_infor.php".$file_infor);
這樣你打來剛生成的file_infor.php文件時,你又看到了熟悉的信息了:
array(
'name'=>'lamp.jpg',
'type'=>'image/pjpeg',
'tmp_name'=>'c:\windows\temp\phpFA.tmp',
'error'=>0,
'size'=>3127
)
當然,真正的處理類于這樣的:
<?php
$upFilePath = "d:/";
);
if($ok === FALSE){
echo json_encode('file_infor'=>'上傳失敗');
}else{
echo json_encode('file_infor'=>'上傳成功');
}
?>
另注:實際上,你可以在一個頁面里嵌入一個IFRAME,然后在IFRAME使用原生的POST表單提交.JQUERY的這個插件也是采用了這種方式。只不過它是動態(tài)生成的IFRAME 與表單
原文: http://fc-lamp.blog.163.com/blog/static/1745666872009519310153/
相關文章
jQuery處理json數(shù)據(jù)返回數(shù)組和輸出的方法
這篇文章主要介紹了jQuery處理json數(shù)據(jù)返回數(shù)組和輸出的方法,涉及jQuery操作數(shù)組及json的技巧,需要的朋友可以參考下2015-03-03jQuery Pagination分頁插件_動力節(jié)點Java學院整理
此jQuery插件為Ajax分頁插件,一次性加載,故分頁切換時無刷新與延遲,如果數(shù)據(jù)量較大不建議用此方法,因為加載會比較慢。下面通過本文給大家分享jQuery Pagination分頁插件的使用方法及參數(shù)介紹,感興趣的朋友一起看看吧2017-07-07jQuery實現(xiàn)的數(shù)值范圍range2dslider選取插件特效多款代碼分享
這篇文章主要介紹了jQuery實現(xiàn)的數(shù)值范圍range2dslider選取插件特效,整體特效非常逼真自然,推薦給大家,有需要的小伙伴可以參考下2015-08-08基于jQuery.validate及Bootstrap的tooltip開發(fā)氣泡樣式的表單校驗組件思路詳解
這篇文章主要介紹了基于jQuery.validate及Bootstrap的tooltip開發(fā)氣泡樣式的表單校驗組件的相關資料,非常不錯,具有參考借鑒價值,感興趣的朋友一起看下吧2016-07-07