Большие загрузки файлов, неустрашные и 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, регистрирующие успех на небольшом видеофайле, но не на большом.

ConsoleScreen

Я играл с типами контента в запросе 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/

Другие вопросы по тегам