Большие загрузки файлов, неустрашные и expressjs
Я создал страницу быстрой загрузки, но у меня возникли проблемы с большими медиа-файлами.
Картинки и видео размером менее 15 Мб загружаются нормально, но все, что больше, выходит из строя с ошибкой 404.
- Dev Lang: JS HTML JQ
- Dev Envir: node@6.10.3, express@4.15.3, body-parser@1.17.2, formidable@1.1.1
Итак, ниже мой Ajax-запрос в форме загрузки, который можно увидеть здесь!
$('.upload-btn').on('click', function () {
var opt_beats = document.getElementById("opt_beats").checked;
var opt_rivers = document.getElementById("opt_rivers").checked;
if (opt_beats == true) {
$('#upload-input').click();
$('.progress-bar').text('0%');
$('.progress-bar').width('0%');
$('#upload-input').on('change', function () {
var files = $(this).get(0).files;
if (files.length > 0) {
// create a FormData object which will be sent as the data payload in the
// AJAX request
var formData = new FormData();
// loop through all the selected files and add them to the formData object
for (var i = 0; i < files.length; i++) {
var file = files[i];
// add the files to formData object for the data payload
formData.append('uploads[]', file, file.name);
}
$.ajax({
url: '/api/uploader/beats',
type: 'POST',
data: formData,
processData: false,
contentType: false,
success: function (data) {
console.log('upload successful!\n' + data);
},
xhr: function () {
// create an XMLHttpRequest
var xhr = new XMLHttpRequest();
// listen to the 'progress' event
xhr.upload.addEventListener('progress', function (evt) {
if (evt.lengthComputable) {
// calculate the percentage of upload completed
var percentComplete = evt.loaded / evt.total;
percentComplete = parseInt(percentComplete *
100);
// update the Bootstrap progress bar with the new percentage
$('.progress-bar').text(percentComplete + '%');
$('.progress-bar').width(percentComplete + '%');
// once the upload reaches 100%, set the progress bar text to done
if (percentComplete === 100) {
$('.progress-bar').html('Done');
}
}
}, false);
return xhr;
}
});
}
});
} else if (opt_rivers == true) {
$('#upload-input').click();
$('.progress-bar').text('0%');
$('.progress-bar').width('0%');
$('#upload-input').on('change', function () {
var files = $(this).get(0).files;
if (files.length > 0) {
// create a FormData object which will be sent as the data payload in the
// AJAX request
var formData = new FormData();
// loop through all the selected files and add them to the formData object
for (var i = 0; i < files.length; i++) {
var file = files[i];
// add the files to formData object for the data payload
formData.append('uploads[]', file, file.name);
}
$.ajax({
url: '/api/uploader/rivers',
type: 'POST',
data: formData,
processData: false,
contentType: false,
success: function (data) {
console.log('upload successful!\n' + data);
},
xhr: function () {
// create an XMLHttpRequest
var xhr = new XMLHttpRequest();
// listen to the 'progress' event
xhr.upload.addEventListener('progress', function (evt) {
if (evt.lengthComputable) {
// calculate the percentage of upload completed
var percentComplete = evt.loaded / evt.total;
percentComplete = parseInt(percentComplete *
100);
// update the Bootstrap progress bar with the new percentage
$('.progress-bar').text(percentComplete + '%');
$('.progress-bar').width(percentComplete + '%');
// once the upload reaches 100%, set the progress bar text to done
if (percentComplete === 100) {
$('.progress-bar').html('Done');
}
}
}, false);
return xhr;
}
});
}
})
}
});
Все это достигает конечной точки API, которую вы можете увидеть ниже:
var express = require('express');
var router = express.Router();
var path = require('path');
var formidable = require('formidable');
var fs = require('fs-extra');
router.post('/beats', function(req, res){
// create an incoming form object
var form = new formidable.IncomingForm();
// specify that we want to allow the user to upload multiple files in a single request
form.multiples = true;
// store all uploads in the /uploads directory
form.uploadDir = path.join(__dirname, '../../public/img/beats');
// every time a file has been uploaded successfully,
// rename it to it's orignal name
form.on('file', function(field, file) {
fs.rename(file.path, path.join(form.uploadDir, file.name));
});
// log any errors that occur
form.on('error', function(err) {
console.log('An error has occured: \n' + err);
});
// once all the files have been uploaded, send a response to the client
form.on('end', function() {
res.end('Upload End');
});
// parse the incoming request containing the form data
form.parse(req);
});
router.post('/rivers', function(req, res){
// create an incoming form object
var form = new formidable.IncomingForm();
// specify that we want to allow the user to upload multiple files in a single request
form.multiples = true;
// store all uploads in the /uploads directory
form.uploadDir = path.join(__dirname, '../../public/img/rivers');
// every time a file has been uploaded successfully,
// rename it to it's orignal name
form.on('file', function(field, file) {
fs.rename(file.path, path.join(form.uploadDir, file.name));
});
// log any errors that occur
form.on('error', function(err) {
console.log('An error has occured: \n' + err);
});
// once all the files have been uploaded, send a response to the client
form.on('end', function() {
res.end('success');
});
// parse the incoming request containing the form data
form.parse(req);
});
module.exports = router;
Снимок экрана ниже: инструменты Chrome Dev, регистрирующие успех на небольшом видеофайле, но не на большом.
Я играл с типами контента в запросе ajax безрезультатно. Я надеюсь, что это простой вид, и у вас есть достаточно информации, чтобы заметить это
Ниже приведен журнал expressjs для запроса:
[2017-10-06T11:54:56.813Z] Warp speed, Mr Sulu on Port: 3000
[2017-10-06T11:54:56.815Z] CAUTION: You are running this in PRODUCTION mode!!!!
express:router dispatching OPTIONS /api/uploader/beats +9s
express:router query : /api/uploader/beats +4ms
express:router expressInit : /api/uploader/beats +3ms
express:router serveStatic : /api/uploader/beats +3ms
express:router jsonParser : /api/uploader/beats +3ms
express:router urlencodedParser : /api/uploader/beats +3ms
express:router <anonymous> : /api/uploader/beats +3ms
express:router <anonymous> : /api/uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +1ms
express:router dispatching OPTIONS /uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +2ms
express:router dispatching OPTIONS /uploader/beats +2ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching OPTIONS /uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +4ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching OPTIONS /uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching OPTIONS /uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +4ms
express:router router /api : /api/uploader/beats +2ms
express:router dispatching OPTIONS /uploader/beats +4ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching OPTIONS /uploader/beats +3ms
express:router trim prefix (/api/uploader) from url /api/uploader/beats +4ms
express:router router /api/uploader : /api/uploader/beats +3ms
express:router dispatching OPTIONS /beats +4ms
express:router dispatching POST /api/uploader/beats +10ms
express:router query : /api/uploader/beats +2ms
express:router expressInit : /api/uploader/beats +1ms
express:router serveStatic : /api/uploader/beats +2ms
express:router jsonParser : /api/uploader/beats +2ms
express:router urlencodedParser : /api/uploader/beats +3ms
express:router <anonymous> : /api/uploader/beats +2ms
express:router <anonymous> : /api/uploader/beats +1ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +0ms
express:router dispatching POST /uploader/beats +1ms
express:router trim prefix (/api) from url /api/uploader/beats +1ms
express:router router /api : /api/uploader/beats +1ms
express:router dispatching POST /uploader/beats +0ms
express:router trim prefix (/api) from url /api/uploader/beats +2ms
express:router router /api : /api/uploader/beats +2ms
express:router dispatching POST /uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +4ms
express:router trim prefix (/api) from url /api/uploader/beats +2ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +4ms
express:router trim prefix (/api) from url /api/uploader/beats +2ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +4ms
express:router trim prefix (/api) from url /api/uploader/beats +2ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +3ms
express:router trim prefix (/api/uploader) from url /api/uploader/beats +2ms
express:router router /api/uploader : /api/uploader/beats +3ms
express:router dispatching POST /beats +2ms
[2017-10-06T11:57:05.828Z] An error has occured:
Error: Request aborted
express:router dispatching POST /api/uploader/beats +2m
express:router query : /api/uploader/beats +3ms
express:router expressInit : /api/uploader/beats +4ms
express:router serveStatic : /api/uploader/beats +3ms
express:router jsonParser : /api/uploader/beats +4ms
express:router urlencodedParser : /api/uploader/beats +3ms
express:router <anonymous> : /api/uploader/beats +4ms
express:router <anonymous> : /api/uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +4ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +4ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +4ms
express:router dispatching POST /uploader/beats +3ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +4ms
express:router dispatching POST /uploader/beats +2ms
express:router trim prefix (/api) from url /api/uploader/beats +4ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +4ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +4ms
express:router dispatching POST /uploader/beats +2ms
express:router trim prefix (/api) from url /api/uploader/beats +3ms
express:router router /api : /api/uploader/beats +2ms
express:router dispatching POST /uploader/beats +2ms
express:router trim prefix (/api) from url /api/uploader/beats +2ms
express:router router /api : /api/uploader/beats +3ms
express:router dispatching POST /uploader/beats +2ms
express:router trim prefix (/api/uploader) from url /api/uploader/beats +3ms
express:router router /api/uploader : /api/uploader/beats +2ms
express:router dispatching POST /beats +3ms
Спасибо
2 ответа
Express ограничивает размер запроса по умолчанию, чтобы изменить ограничение для одного маршрута, вы можете сделать это следующим образом:
const bodyParser = require('body-parser');
app.post('/beats', bodyParser.raw({ limit : '20mb', type : '*/*'}), function(req, res) {
...
});
Не уверен, что это ошибка, поскольку вы не упомянули ни одного журнала на экспресс-стороне, поэтому дайте мне знать
Длина содержимого по умолчанию составляет приблизительно 30 МБ. Добавление этой строки в файл web.config решит проблему. Это позволит 40 МБ.
<security>
<requestFiltering>
<requestLimits maxAllowedContentLength="40000000"/>
</requestFiltering>
</security>
Ссылочная ссылка: https://docs.microsoft.com/en-us/iis/configuration/system.webServer/security/requestFiltering/requestLimits/