ファイルアップロード機能があり、html5のスライスapiを使用して、各ファイルを1MBのチャンクにスライスしますが、最終的な結果でファイルが破損します。時には、最終結果が元のファイルよりも小さく、時には正しいサイズであっても、私はまだそれを開くことができません。誰もが考えている?またはソリューションですか? 私は私のPHPコードをサーバー上で一緒にファイルを入れたときに、私は何か間違ったことをしたと思う。これはHTML5スライス、結果ファイルが壊れています
var uploaders = [];
var i = 0;
$(document).ready(function() {
var progress = document.querySelector('progress');
var bars = document.querySelector('#bars');
});
//function for after the button is clicked, slice the file
//and call upload function
function sendRequest() {
//clean the screen
bars.innerHTML = '';
var blob = document.getElementById('fileToUpload').files[0];
var originalFileName = blob.name;
const BYTES_PER_CHUNK = 1 * 1024 * 1024; // 10MB chunk sizes.
const SIZE = blob.size;
var start = 0;
var end = BYTES_PER_CHUNK;
while(start < SIZE) {
if (blob.webkitSlice) {
var chunk = blob.webkitSlice(start, end);
} else if (blob.mozSlice) {
var chunk = blob.mozSlice(start, end);
}
uploadFile(chunk, originalFileName);
start = end;
end = start + BYTES_PER_CHUNK;
}
}
function uploadFile(blobFile, fileName) {
var progress = document.createElement('progress');
progress.min = 0;
progress.max = 100;
progress.value = 0;
bars.appendChild(progress);
var fd = new FormData();
fd.append("fileToUpload", blobFile);
var xhr = new XMLHttpRequest();
xhr.open("POST", "upload.php"+"?"+"file="+fileName + i, true);
i++;
xhr.onload = function(e) {
//make sure if finish progress bar at 100%
progress.value = 100;
//counter if everything is done using stack
uploaders.pop();
if (!uploaders.length) {
bars.appendChild(document.createElement('br'));
bars.appendChild(document.createTextNode('DONE :)'));
}
};
// Listen to the upload progress for each upload.
xhr.upload.onprogress = function(e) {;
if (e.lengthComputable) {
progress.value = (e.loaded/e.total) * 100;
}
};
uploaders.push(xhr);
xhr.send(fd);
}
をスライスするための部分であり、これはバイナリチャンク
<?php
$target_path = "uploads/";
$tmp_name = $_FILES['fileToUpload']['tmp_name'];
$size = $_FILES['fileToUpload']['size'];
$name = $_FILES['fileToUpload']['name'];
$originalName = $_GET['file1'];
print_r("*******************************************\n");
print_r($originalName);
print_r("\n");
print_r($_FILES);
print_r("\n");
print_r("*******************************************\n");
$target_file = $target_path . basename($name);
//Result File
$complete = $originalName;
$com = fopen("uploads/".$complete, "ab");
error_log($target_path);
if ($com) {
// Read binary input stream and append it to temp file
$in = fopen($tmp_name, "rb");
if ($in) {
while ($buff = fread($in, 1048576)) {
fwrite($com, $buff);
}
}
fclose($in);
fclose($com);
}
?>
を受け入れるためのPHPファイルであります(私はそれを順序や何かに入れないのと同じように)、だれかがこのやベストプラクティスをやる方法を知っているのだろうか?ファイルをアップロードして組み合わせるのではなく、ファイルに実際に書き込む前に、まずメモリに保存しておいてください。
あなたuploadprogressの機能を提供してください。変数bar(div?)はスクリプト内で定義されていません。また、uploaders変数の値を省略しています(配列なのですか?) – Martin
@Martinコードを更新しました。これは、コード全体を表しています。ファイルのアップロードのための通常のhtmlタグを除いて – Harts