因此,我尝试学习PHP和JS,并想为运行OpenWRT的家用路由器构建文件上传器。我遵循了很多指南,并建立了令人满意的指南。但是,当我开始使用较大的文件(> 5mb)时,路由器本身开始崩溃。上载11MB文件时,路由器可能在上载30%-75%之间的任何地方崩溃。我已经编辑了php.ini,如本网站上其他文章所建议的那样,以支持更大的文件和更长的php脚本运行时间。我也已经开始研究用于文件上传的分块,但是想确认我的问题首先出在哪里。如果我的代码草率,我深表歉意,但我仍在努力弄清一切。
function _(el) {
return document.getElementById(el);
}
function uploadFile() {
document.getElementById('progressBar').style.display = "block";
var file = _("file1").files[0];
if(_("file1").files[0] == null){
_("status").innerHTML = "You Must Select a File";
}
else{
// alert(file.name+" | "+file.size+" | "+file.type);
var formdata = new FormData();
formdata.append("file1", file);
var ajax = new XMLHttpRequest();
ajax.upload.addEventListener("progress", progressHandler, false);
ajax.addEventListener("load", completeHandler, false);
ajax.addEventListener("error", errorHandler, false);
ajax.addEventListener("abort", abortHandler, false);
ajax.open("POST", "UPLOADER.php");
ajax.send(formdata);
}
}
<form id="upload_form" enctype="multipart/form-data" method="post">
<input type="file" name="file1" id="file1" class="inputfile" data-multiple-caption="{count} files selected" multiple />
<button onclick="uploadFile()" class="buttonUpload">Upload</button>
</form>
我的PHP是
<?php
ini_set('upload_max_filesize', '40M');
ini_set('post_max_size', '40M');
ini_set('max_input_time', 300);
ini_set('max_execution_time', 300);
$fileName = $_FILES["file1"]["name"]; // The file name
$fileTmpLoc = $_FILES["file1"]["tmp_name"]; // File in the PHP tmp folder
$fileType = $_FILES["file1"]["type"]; // The type of file it is
$fileSize = $_FILES["file1"]["size"]; // File size in bytes
$fileErrorMsg = $_FILES["file1"]["error"]; // 0 for false... and 1 for true
if (!$fileTmpLoc) { // if file not chosen
echo "ERROR: Please browse for a file before clicking the upload button.";
exit();
}
if(move_uploaded_file($fileTmpLoc, "Home/$fileName")){
echo "$fileName upload is complete";
} else {
echo "move_uploaded_file function failed";
}
?>
所以看来我的问题是我需要使用分块执行上传。我已经看过所有的插件,例如resumable.js和plupload,但我真的很想了解如何在已有的代码范围内执行此操作。有可能吗?