亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

基于PHP的AJAX技術實現文件異步上傳

2024-09-01 08:30:04
字體:
來源:轉載
供稿:網友

異步的文件上傳是在現代的AJAX實現的Web應用里面經常要遇到,必須解決的問題。但是標準的AJAX類(XMLHttpRequest)無法實現傳輸文件的功能。因此,這里討論的內容就是如何在AJAX的技術的基礎之上構建異步的文件上傳功能。在這個功能當中需要使用到內置的框及(IFRAME)來傳輸文件。這個功能實現的效果是頁面在上傳文件的時候,用戶還可以使用該頁面并且填寫文件描述。

這個例子是我們引用AJAX的經典案例進行分析的。

系統環境

· 較新版本的瀏覽器。例如Opera,Firefox或者 Internet Explorer。

· PHP 4.3.0 或更高版本

· PHP 5 版本

· PHP 中的 'short_open_tag' 選項開啟(否則會發生解析錯誤)。

功能分析

通過內置的IFRAME(框架)進行文件上傳。具備包括三個部分組成。

· 在頁面中間有一個簡單的<form...表單,表單只包含了<input type="file" ... >控件。這個表單的目標鏈接就是一個隱藏得IFRAME(通過 CSS的風格" display: none;"實現)并且表單里面唯一一個控件的OnChange事件用來觸發JavaScript函數。這個函數的作用是檢查用戶提交的擴展名,然后提交表單。

· 在服務器端用PHP編寫了一個處理過程(用FILEFRAME坐注釋了)。這個處理過程用來把從客戶端上傳的文件進行檢查后保存在服務器,并且通過javascript代碼的形式返回給用戶。返回給用戶的Javascript腳本通過"parent.window.document"更改了用戶現在正在查看的頁面,設置了文件的名稱并啟用了讓用戶提交表單的按鈕。啟用按鈕的操作是通過getElementById函數實現的。

· 在主頁面還有一個表單,它包含了用戶提交的描述和隱藏的文件名。用戶可以在文件上傳的同時填寫文件的描述。當文件上傳結束以后,用戶點擊按鈕,就可以看上傳以后返回給用戶的文件信息了。(通過返回來的文件名和用戶輸入的描述構成文件信息)。

可能你會說這么操作不符合常理:文件在用戶確認之前就已經被提交了。如果用戶沒有提交的話,情況會如何呢。你可以自己在擴展處理被用戶放棄的文件。

這個例子把文件存儲在一個文件系統的目錄下。你需要在腳本開始運行的時候配置下這個目錄,具體的包含這個目錄信息的變量是$upload_dir 和$web_upload_dir。這里有一個對目錄是否可寫的權限檢查。

這里我們用到了以下幾個PHP函數:

· move_uploaded_file - 轉移一經上傳到服務器的文件

· fopen - 打開文件

· fwrite - 把內容寫入文件

· fclose - 關閉文件

· str_replace - 替換字符串

· filesize - 返回文件大小

· filemtime - 返回處理時間

你可以通過手冊查到這些函數如果使用。請注意要把HTM(<, >, &)標記替換為(<, > 和 &)。

源代碼

以下為引用的內容:

<?PHP
$upload_dir = "/var/www/anyexample/aeu"; // 文件存儲的路徑
$web_upload_dir = "/aeu"; // 文件在Web目錄下的路徑
$tf = $upload_dir.'/'.md5(rand()).".test";
$f = @fopen($tf, "w");
if ($f == false)
die("Fatal error! {$upload_dir} is not writable. Set 'chmod 777 {$upload_dir}'
or something like this");
fclose($f);
unlink($tf);

//處理上傳的文件
if (isset($_POST['fileframe']))
{
 $result = 'ERROR';
 $result_msg = 'No FILE field found';

 if (isset($_FILES['file'])) // 從瀏覽器接受文件
 {
  if ($_FILES['file']['error'] == UPLOAD_ERR_OK) // 沒有錯誤
  {
   $filename = $_FILES['file']['name']; // 文件名
   move_uploaded_file($_FILES['file']['tmp_name'], $upload_dir.'/'.$filename);
   // 處理的主過程-轉移文件到 $upload_dir
   $result = 'OK';
  }
  elseif ($_FILES['file']['error'] == UPLOAD_ERR_INI_SIZE)
   $result_msg = 'The uploaded file exceeds the upload_max_filesize directive in PHP.ini';
  else
   $result_msg = 'Unknown error';
 }

 echo '<html><head><title>-</title></head><body>';
 echo '<script language="javascript" type="text/Javascript">'."/n";
 echo 'var parDoc = window.parent.document;';
 '
 if ($result == 'OK')
 {
  echo 'parDoc.getElementById("upload_status").value = "file successfully uploaded";';
  echo 'parDoc.getElementById("filename").value = "'.$filename.'";';
  echo 'parDoc.getElementById("filenamei").value = "'.$filename.'";';
  echo 'parDoc.getElementById("upload_button").disabled = false;';
 }
 else
 {
  echo 'parDoc.getElementById("upload_status").value = "ERROR: '.$result_msg.'";';
 }

 echo "/n".'</script></body></html>';
 exit();
}

function safehtml($s)
{
 $s=str_replace("&", "&", $s);
 $s=str_replace("<", "<", $s);
 $s=str_replace(">", ">", $s);
 $s=str_replace("'", "'", $s);
 $s=str_replace("/"", """, $s);
 return $s;
}

if (isset($_POST['description']))
{
 $filename = $_POST['filename'];
 $size = filesize($upload_dir.'/'.$filename);
 $date = date('r', filemtime($upload_dir.'/'.$filename));
 $description = safehtml($_POST['description']);

 $html =<<<END
?。糷tml><head><title>{$filename} [uploaded by IFRAME Async file uploader]</title></head>
?。糱ody>
 ?。糷1>{$filename}</h1>
 ?。紁>This is a file information page for your uploaded file. Bookmark it, or send to anyone...</p>
 ?。紁>Date: {$date}</p>
 ?。紁>Size: {$size} bytes</p>
 ?。紁>Description:
 ?。紁re>{$description}</pre>
 ?。?p>
 ?。紁><a href="{$web_upload_dir}/{$filename}" style="font-size: large;">download file</a><br>
  <a href="{$PHP_SELF}" style="font-size: small;">back to file uploading</a><br>
 ?。糰 href="{$web_upload_dir}/upload-log.html" style="font-size: small;">upload-log</a></p>
  <br><br>Example by <a href="http://www.anyexample.com/">AnyExample</a>
?。?body></html>
 END;
 
 $f = fopen($upload_dir.'/'.$filename.'-desc.html', "w");
 fwrite($f, $html);
 fclose($f);
 $msg = "File {$filename} uploaded,
?。糰 href='{$web_upload_dir}/{$filename}-desc.html'>see file information page</a>";

 $f = fopen($upload_dir."/upload-log.html", "a");
 fwrite($f, "<p>$msg</p>/n");
 fclose($f);

 setcookie('msg', $msg);
 header("Location: http://".$_SERVER['HTTP_HOST'].$PHP_SELF);
 exit();
}

if (isset($_COOKIE['msg']) && $_COOKIE['msg'] != '')
{
 if (get_magic_quotes_gpc())
  $msg = stripslashes($_COOKIE['msg']);
 else
  $msg = $_COOKIE['msg'];
  setcookie('msg', '');
}
?>
<!-- Beginning of main page -->
<html><head>
<title>IFRAME Async file uploader example</title>
</head>
<body>
<?PHP
 if (isset($msg))
  echo '<p style="font-weight: bold;">'.$msg.'</p>';
?>
<h1>Upload file:</h1>
<p>File will begin to upload just after selection. </p>
<p>You may write file description, while you file is being uploaded.</p>

<form action="<?=$PHP_SELF?>" target="upload_iframe" method="post" enctype="multipart/form-data">
 <input type="hidden" name="fileframe" value="true">
?。?-- Target of the form is set to hidden iframe -->
 <!-- From will send its post data to fileframe section of this PHP script (see above) -->

?。糽abel for="file">text file uploader:</label><br>
?。?-- JavaScript is called by OnChange attribute -->
?。糹nput type="file" name="file" id="file" onChange="jsUpload(this)">
</form>
<script type="text/Javascript">
/* This function is called when user selects file in file dialog */
function jsUpload(upload_field)
{
 // this is just an example of checking file extensions
 // if you do not need extension checking, remove
 // everything down to line
 // upload_field.form.submit();
 
 var re_text = //.txt|/.XML|/.zip/i;
 var filename = upload_field.value;

 /* Checking file type */
 if (filename.search(re_text) == -1)
 {
  alert("File does not have text(txt, XML, zip) extension");
  upload_field.form.reset();
  return false;
 }

 upload_field.form.submit();
 document.getElementById('upload_status').value = "uploading file...";
 upload_field.disabled = true;
 return true;
}
</script>
<iframe name="upload_iframe" style="width: 400px; height: 100px; display: none;">
</iframe>
<!-- For debugging purposes, it's often useful to remove
"display: none" from style="" attribute -->

<br>
Upload status:<br>
<input type="text" name="upload_status" id="upload_status"
value="not uploaded" size="64" disabled>
<br><br>

File name:<br>
<input type="text" name="filenamei" id="filenamei" value="none" disabled>

<form action="<?=$PHP_SELF?>" method="POST">
?。?-- one field is "disabled" for displaying-only. Other, hidden one is for sending data -->
?。糹nput type="hidden" name="filename" id="filename">
?。糱r><br>

?。糽abel for="photo">File description:</label><br>
 <textarea rows="5" cols="50" name="description"></textarea>

?。糱r><br>
?。糹nput type="submit" id="upload_button" value="save file" disabled>
</form>
<br><br>
<a href="<?=$web_upload_dir?>/upload-log.html">upload-log</a>
<br><br><br>

Example by <a href="http://www.anyexample.com/">AnyExample</a>
</body>
</html>

以上的講解就是提供一種思路供大家參考。大家也可以根據自己的需求進行相應的優化。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
清纯唯美日韩制服另类| 国产精品日韩欧美| 4438全国亚洲精品在线观看视频| 亚洲欧洲激情在线| 亚洲国产另类久久精品| 在线观看视频亚洲| 日韩精品福利在线| 中文字幕国产精品| 亚洲热线99精品视频| 国产精品视频导航| 欧美日韩在线免费| …久久精品99久久香蕉国产| 亚洲精品国精品久久99热| 成人福利视频网| 欧美一级电影免费在线观看| 亚洲va欧美va国产综合剧情| 日本欧美一二三区| 97热在线精品视频在线观看| 日韩的一区二区| 亚洲经典中文字幕| 欧美激情网站在线观看| 国产精品福利片| 欧美日韩精品在线观看| 日韩不卡在线观看| 国产美女91呻吟求| 国产精品网红福利| 色777狠狠综合秋免鲁丝| 亚洲精品日韩激情在线电影| 91精品视频在线播放| 不卡av在线播放| 欧美视频一二三| 91亚洲精品一区二区| 久久久极品av| 欧美大片在线看免费观看| 最近2019年中文视频免费在线观看| 欧美日韩成人黄色| 欧美亚洲成人网| 日韩经典中文字幕在线观看| 久久人人爽人人爽人人片av高请| 九九精品在线视频| 久久婷婷国产麻豆91天堂| 国内外成人免费激情在线视频网站| 亚洲剧情一区二区| 久久五月情影视| 成人中文字幕+乱码+中文字幕| 亚洲欧美三级伦理| 国产视频精品久久久| 欧美在线观看www| 欧美二区在线播放| 国产一区二区成人| 日韩av一卡二卡| 久久亚洲综合国产精品99麻豆精品福利| 欧美肥臀大乳一区二区免费视频| 亚洲第一页在线| 日韩在线观看网站| 日韩色av导航| 国产精品电影久久久久电影网| 精品一区二区三区四区| 欧美日韩电影在线观看| 精品偷拍各种wc美女嘘嘘| 久久99久久久久久久噜噜| 亚洲另类xxxx| 欧美精品午夜视频| 亚洲第一精品夜夜躁人人爽| 在线播放精品一区二区三区| 91在线免费网站| 国产精品露脸自拍| 亚洲成人av片| 国产成人小视频在线观看| 国产亚洲美女精品久久久| 久久精品成人一区二区三区| 深夜福利亚洲导航| 欧美成人精品xxx| 少妇高潮久久77777| 国产亚洲激情在线| 日韩高清电影免费观看完整| 懂色aⅴ精品一区二区三区蜜月| 97欧美精品一区二区三区| 亚洲人午夜精品| 中文字幕国产精品| 亚洲精品不卡在线| 欧美精品中文字幕一区| 精品视频偷偷看在线观看| 国产亚洲成av人片在线观看桃| 亚洲网站视频福利| 国产精品美乳一区二区免费| 欧美黄色片在线观看| 日韩欧美中文字幕在线观看| 亚洲精品在线观看www| 中文字幕欧美日韩va免费视频| 亚洲aa中文字幕| 欧美激情精品久久久久| 日韩电影中文字幕av| 68精品国产免费久久久久久婷婷| 北条麻妃一区二区三区中文字幕| 久久影视电视剧凤归四时歌| 久久久久国色av免费观看性色| 庆余年2免费日韩剧观看大牛| 欧美亚洲视频在线看网址| 国产香蕉97碰碰久久人人| 国语自产精品视频在线看| 欧美黑人一级爽快片淫片高清| 91精品久久久久久久久久久久久| 成人激情综合网| 亚洲精品日韩丝袜精品| 日韩精品在线视频| 日韩的一区二区| 亚洲偷欧美偷国内偷| 91精品国产九九九久久久亚洲| 国产欧美精品va在线观看| 久久久久久国产精品三级玉女聊斋| 亚州精品天堂中文字幕| 日韩在线激情视频| 欧美成年人网站| 欧美成年人视频| 国产69精品99久久久久久宅男| 日韩最新中文字幕电影免费看| 亚洲国产精品嫩草影院久久| 国产又爽又黄的激情精品视频| 国产精品永久免费视频| 亚洲自拍偷拍色片视频| 中文字幕亚洲一区| 精品中文字幕在线| 久久久免费高清电视剧观看| 久操成人在线视频| 高潮白浆女日韩av免费看| 日本视频久久久| 最近2019中文免费高清视频观看www99| 精品中文字幕视频| 黑人欧美xxxx| 精品视频9999| 日韩av大片在线| 久久影院中文字幕| 午夜精品福利视频| 欧美日韩黄色大片| 欧美亚州一区二区三区| 久久久在线视频| 国产不卡精品视男人的天堂| 日韩国产高清视频在线| 欧美裸体xxxx极品少妇软件| 中文字幕日韩电影| 成人久久18免费网站图片| 最新国产成人av网站网址麻豆| 欧美成人精品一区二区三区| 日韩亚洲欧美成人| 疯狂蹂躏欧美一区二区精品| 亚洲日本成人女熟在线观看| 亚洲成色999久久网站| 久久天天躁狠狠躁夜夜躁| 96sao精品视频在线观看| 一色桃子一区二区| 国产91在线视频| 亚洲黄色www| 中文字幕免费国产精品| 在线观看欧美成人| 欧美另类暴力丝袜| 日韩精品在线免费观看视频| 久久国产精品久久精品| 日韩中文在线不卡| 精品亚洲一区二区三区四区五区| 中文字幕精品一区二区精品| 亚洲美女黄色片| 色综久久综合桃花网| 色偷偷av一区二区三区|