Как загрузить большой файл в экспресс с индикатором выполнения?
В настоящее время я использую socket.io
для загрузки видео с индикатором выполнения. Вот учебник
http://net.tutsplus.com/tutorials/javascript-ajax/how-to-create-a-resumable-video-uploade-in-node-js/
но Internet Explorer не поддерживает этот метод, но мне действительно нужно загрузить видео во всех браузерах.
Я проверил экспресс-документацию. Поскольку экспресс основан на node-formidable
(который имеет событие прогресса), я думаю, что есть способ создать систему загрузки с индикатором выполнения, правильно? Я просто не знаю, как!
Является ли node -формируемым IE включенным?
В любом случае можно создать систему загрузки файлов в чистом espress.js с индикатором выполнения?
Ответы
Ответ 1
Это можно сделать с событием прогресса xhr.upload. Он поддерживается html5.
Например:
https://github.com/zeMirco/express-upload-progress
В php информация о загрузке может быть присоединена к сеансу, поэтому она работает с html4, возможно, для этого есть расширение nodejs, я буду google.
В соответствии с этим:
Как сделать загрузку с помощью экспресс-доставки в node.js
есть событие прогресса в экспресс путем загрузки файла, поэтому вы можете установить переменную в сеансе с фактическими данными прогресса и прочитать ее с помощью ajax с клиентской стороны.
Ответ 2
Вот jsfiddle, используя angular js и ng-file-upload.
jsfiddle работает для изображений и файлов, но для загрузки видеороликов вам будет изменен URL-адрес POST на ваш сервер.
//inject angular file upload directives and services.
var app = angular.module('fileUpload', ['ngFileUpload']);
app.controller('MyCtrl', ['$scope', 'Upload', '$timeout', function($scope, Upload, $timeout) {
$scope.uploadFiles = function(file, errFiles) {
$scope.f = file;
$scope.errFile = errFiles && errFiles[0];
if (file) {
file.upload = Upload.upload({
url: 'https://angular-file-upload-cors-srv.appspot.com/upload',
data: {
file: file
}
});
file.upload.then(function(response) {
$timeout(function() {
file.result = response.data;
});
}, function(response) {
if (response.status > 0)
$scope.errorMsg = response.status + ': ' + response.data;
}, function(evt) {
file.progress = Math.min(100, parseInt(100.0 *
evt.loaded / evt.total));
});
}
}
}]);
.thumb {
width: 24px;
height: 24px;
float: none;
position: relative;
top: 7px;
}
form .progress {
line-height: 15px;
}
.progress {
display: inline-block;
width: 100px;
border: 3px groove #CCC;
}
.progress div {
font-size: smaller;
background: orange;
width: 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<script src="https://angular-file-upload.appspot.com/js/ng-file-upload-shim.js"></script>
<script src="https://angular-file-upload.appspot.com/js/ng-file-upload.js"></script>
<body ng-app="fileUpload" ng-controller="MyCtrl">
<h4>Upload on file select</h4>
<button type="file" ngf-select="uploadFiles($file, $invalidFiles)" ngf-max-height="1000" ngf-max-size="100MB">
Select File</button>
<br>
<br> File:
<div style="font:smaller">{{f.name}} {{errFile.name}} {{errFile.$error}} {{errFile.$errorParam}}
<span class="progress" ng-show="f.progress >= 0">
<div style="width:{{f.progress}}%"
ng-bind="f.progress + '%'"></div>
</span>
</div>
{{errorMsg}}
</body>