濮阳杆衣贸易有限公司

主頁 > 知識庫 > php+ajax實(shí)現(xiàn)文件切割上傳功能示例

php+ajax實(shí)現(xiàn)文件切割上傳功能示例

熱門標(biāo)簽:南京3D地圖標(biāo)注 辦理400電話哪家好點(diǎn) 咸陽電銷 重慶外呼電銷系統(tǒng)多少錢 正規(guī)電銷機(jī)器人系統(tǒng) 邢臺400電話辦理 南寧電話外呼系統(tǒng)線路 濟(jì)源百應(yīng)電銷機(jī)器人聯(lián)系方式 嘟嘟云外呼系統(tǒng)

本文實(shí)例講述了php+ajax實(shí)現(xiàn)文件切割上傳功能。分享給大家供大家參考,具體如下:

html5中的File對象繼承Blob二進(jìn)制對象,Blob提供了一個(gè)slice函數(shù),可以用來切割文件數(shù)據(jù)。

!DOCTYPE HTML>
html lang="zh-CN">
head>
  meta charset="UTF-8">
  title>/title>
/head>
body>
  form method="post" id="myForm">
    input type="file" name="file" id="upfile" />
    input type="submit" name="submit" value="提交" />
  /form>
  div id="upStatus">/div>
/body>
script type="text/javascript">
  var myForm = document.getElementById("myForm");
  var upfile = document.getElementById("upfile");

  myForm.onsubmit = function() {
    //獲取文件對象
    var file = upfile.files[0];
    //獲取文件大小
    var fileSize = file.size;
    //一次截取的大小(字節(jié))
    var CutSize = 1024 * 1024 * 10;
    //開始截取位置
    var CutStart = 0;
    //結(jié)束截取位置
    var CutEnd = CutStart + CutSize;
    //截取的臨時(shí)文件
    var tmpfile = new Blob();

    while(CutStart  fileSize) {
      tmpfile = file.slice(CutStart, CutEnd);

      //我們創(chuàng)建一個(gè)FormData對象
      var fd = new FormData();
      //把文件添加到FormData對象中
      fd.append("file", tmpfile);

      var xhr = new XMLHttpRequest();
      //這里使用同步
      xhr.open("post", "upfile.php", false);

      //上傳進(jìn)度
      console.log(Math.round( (CutStart + tmpfile.size) / fileSize * 100) + "%");

      //發(fā)送FormData對象
      xhr.send(fd);
      //重新設(shè)置截取文件位置
      CutStart = CutEnd;
      CutEnd = CutStart + CutSize;
    }
    return false;
  };
/script>
/html>

upfile.php代碼如下:

?php
$uploadDir = './upload/';
if(!file_exists($uploadDir)) {
  @mkdir($uploadDir, 0777, true);
}
$uploadFile = $uploadDir . basename($_FILES['file']['name']);

if(!file_exists($uploadFile)) {
  //如果文件不存在
  move_uploaded_file($_FILES['file']['tmp_name'], $uploadFile);
} else {
  //如果文件已存在,追加數(shù)據(jù)
  file_put_contents($uploadFile, file_get_contents($_FILES['file']['tmp_name']), FILE_APPEND);
}

更多關(guān)于PHP相關(guān)內(nèi)容可查看本站專題:《PHP+ajax技巧與應(yīng)用小結(jié)》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP大文件切割上傳并帶進(jìn)度條功能示例
  • PHP大文件切割上傳功能實(shí)例分析
  • PHP大文件分割上傳 PHP分片上傳
  • PHP搭建大文件切割分塊上傳功能示例
  • php+ajax實(shí)現(xiàn)圖片文件上傳功能實(shí)例
  • 使用ajaxfileupload.js實(shí)現(xiàn)ajax上傳文件php版
  • php+ajax實(shí)現(xiàn)異步上傳文件或圖片功能
  • File, FileReader 和 Ajax 文件上傳實(shí)例分析(php)
  • PHP+Ajax異步帶進(jìn)度條上傳文件實(shí)例
  • PHP結(jié)合jQuery插件ajaxFileUpload實(shí)現(xiàn)異步上傳文件實(shí)例

標(biāo)簽:隴南 黃山 武漢 平頂山 南通 河南 通遼 唐山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《php+ajax實(shí)現(xiàn)文件切割上傳功能示例》,本文關(guān)鍵詞  php+ajax,實(shí)現(xiàn),文件,切割,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《php+ajax實(shí)現(xiàn)文件切割上傳功能示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于php+ajax實(shí)現(xiàn)文件切割上傳功能示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    长白| 准格尔旗| 四子王旗| 青川县| 英德市| 神木县| 丰宁| 丽江市| 凤阳县| 宁海县| 肇源县| 麟游县| 望奎县| 三原县| 开原市| 通辽市| 德兴市| 东乡族自治县| 正宁县| 介休市| 股票| 称多县| 玉龙| 新巴尔虎右旗| 颍上县| 德保县| 灵宝市| 都昌县| 衡阳县| 娱乐| 乃东县| 屏山县| 昌邑市| 南汇区| 澳门| 洛隆县| 会泽县| 盘山县| 津南区| 陈巴尔虎旗| 凤山县|