这篇文章将为大家详细讲解有关怎么在php中使用resumablejs实现分块上传,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
upload.html
<!DOCTYPE html> <html lang="en"> <div> <a href="#" rel="external nofollow" id="browseButton" >Select files</a> <div> <div> <input id="btnCancel" type="button" onClick='r.pause()'value="Cancel All Uploads" /> <br /> </div> <script src="resumable.js"></script> <script> var r = new Resumable({ target:'upload.php', chunkSize:2*1024*1024, simultaneousUploads:4, testChunks:true, throttleProgressCallbacks:1, }); r.assignBrowse(document.getElementById('browseButton')); r.on('fileSuccess', function(file){ // console.debug(file); }); r.on('fileProgress', function(file){ // console.debug(file); }); r.on('fileAdded', function(file, event){ r.upload(); //console.debug(file, event); }); r.on('fileRetry', function(file){ //console.debug(file); }); r.on('fileError', function(file, message){ //console.debug(file, message); }); r.on('uploadStart', function(){ //console.debug(); }); r.on('complete', function(){ //console.debug(); }); r.on('progress', function(){ //console.debug(); }); r.on('error', function(message, file){ //console.debug(message, file); }); r.on('pause', function(file,message){ //console.debug(); }); r.on('cancel', function(){ //console.debug(); }); </script> </html>
upload.php
<?php /** * This is the implementation of the server side part of * Resumable.js client script, which sends/uploads files * to a server in several chunks. * * The script receives the files in a standard way as if * the files were uploaded using standard HTML form (multipart). * * This PHP script stores all the chunks of a file in a temporary * directory (`temp`) with the extension `_part<#ChunkN>`. Once all * the parts have been uploaded, a final destination file is * being created from all the stored parts (appending one by one). * * @author Gregory Chris (http://online-php.com) * @email www.online.php@gmail.com */ //////////////////////////////////////////////////////////////////// // THE FUNCTIONS //////////////////////////////////////////////////////////////////// /** * * Logging operation - to a file (upload_log.txt) and to the stdout * @param string $str - the logging string */ function _log($str) { // log to the output $log_str = date('d.m.Y').": {$str}\r\n"; echo $log_str; // log to file if (($fp = fopen('upload_log.txt', 'a+')) !== false) { fputs($fp, $log_str); fclose($fp); } } /** * * Delete a directory RECURSIVELY * @param string $dir - directory path * @link http://php.net/manual/en/function.rmdir.php */ function rrmdir($dir) { if (is_dir($dir)) { $objects = scandir($dir); foreach ($objects as $object) { if ($object != "." && $object != "..") { if (filetype($dir . "/" . $object) == "dir") { rrmdir($dir . "/" . $object); } else { unlink($dir . "/" . $object); } } } reset($objects); rmdir($dir); } } /** * * Check if all the parts exist, and * gather all the parts of the file together * @param string $dir - the temporary directory holding all the parts of the file * @param string $fileName - the original file name * @param string $chunkSize - each chunk size (in bytes) * @param string $totalSize - original file size (in bytes) */ function createFileFromChunks($temp_dir, $fileName, $chunkSize, $totalSize) { // count all the parts of this file $total_files = 0; foreach(scandir($temp_dir) as $file) { if (stripos($file, $fileName) !== false) { $total_files++; } } // check that all the parts are present // the size of the last part is between chunkSize and 2*$chunkSize if ($total_files * $chunkSize >= ($totalSize - $chunkSize + 1)) { // create the final destination file if (($fp = fopen('temp/'.$fileName, 'w')) !== false) { for ($i=1; $i<=$total_files; $i++) { fwrite($fp, file_get_contents($temp_dir.'/'.$fileName.'.part'.$i)); _log('writing chunk '.$i); } fclose($fp); } else { _log('cannot create the destination file'); return false; } // rename the temporary directory (to avoid access from other // concurrent chunks uploads) and than delete it if (rename($temp_dir, $temp_dir.'_UNUSED')) { rrmdir($temp_dir.'_UNUSED'); } else { rrmdir($temp_dir); } } } //////////////////////////////////////////////////////////////////// // THE SCRIPT //////////////////////////////////////////////////////////////////// //check if request is GET and the requested chunk exists or not. this makes testChunks work if ($_SERVER['REQUEST_METHOD'] === 'GET') { $temp_dir = 'temp/'.$_GET['resumableIdentifier']; $chunk_file = $temp_dir.'/'.$_GET['resumableFilename'].'.part'.$_GET['resumableChunkNumber']; if (file_exists($chunk_file)) { header("HTTP/1.0 200 Ok"); } else { header("HTTP/1.0 404 Not Found"); } } // loop through files and move the chunks to a temporarily created directory if (!empty($_FILES)) foreach ($_FILES as $file) { // check the error status if ($file['error'] != 0) { _log('error '.$file['error'].' in file '.$_POST['resumableFilename']); continue; } // init the destination file (format <filename.ext>.part<#chunk> // the file is stored in a temporary directory $temp_dir = 'temp/'.$_POST['resumableIdentifier']; $dest_file = $temp_dir.'/'.$_POST['resumableFilename'].'.part'.$_POST['resumableChunkNumber']; // create the temporary directory if (!is_dir($temp_dir)) { mkdir($temp_dir, 0777, true); } // move the temporary file if (!move_uploaded_file($file['tmp_name'], $dest_file)) { _log('Error saving (move_uploaded_file) chunk '.$_POST['resumableChunkNumber'].' for file '.$_POST['resumableFilename']); } else { // check if all the parts present, and create the final destination file createFileFromChunks($temp_dir, $_POST['resumableFilename'], $_POST['resumableChunkSize'], $_POST['resumableTotalSize']); } }
关于怎么在php中使用resumablejs实现分块上传就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。