Я использую Multer для загрузки изображений в Express 4. Однако все примеры показывают, что Multer определяется в экспресс файле как Middleware. Я бы хотел определить некоторые из поведения Multer в моей маршрутизации приложения. Это возможно? Конечным результатом, который мне нужен, является то, что моя функция маршрута распознает, когда загрузка завершена до того, как он отправит ответ сервера в браузер, так что изображение может быть отображено пользователю (прямо сейчас я получаю только частичное изображение, потому что файл еще не завершил загрузку).
ТЕКУЩИЙ, РАБОЧИЙ КОД
express.js
// Require Multer as module dependency.
var multer = require('multer');
// Using Multer for file uploads.
app.use(multer({
dest: './public/profile/img/',
limits: {
fieldNameSize: 50,
files: 1,
fields: 5,
fileSize: 1024 * 1024
},
rename: function(fieldname, filename) {
return filename;
},
onFileUploadStart: function(file) {
if(file.mimetype !== 'image/jpg' && file.mimetype !== 'image/jpeg' && file.mimetype !== 'image/png') {
return false;
}
}
}));
server_routes.js
app.route('/users/image').post(server_controller_file.imageUpload);
server_controller_file.js
exports.imageUpload = function(req, res) {
// Check to make sure req.files contains a file, mimetypes match, etc., then send appropriate server response.
};
В идеале, мой server_controller_file.js будет содержать некоторые проверки, чтобы убедиться, что файл завершил загрузку, например. (обратите внимание: это гипотетический/желательный, а не фактический рабочий код)...
var multer = require('multer');
exports.imageUpload = function(req, res) {
multer({
onFileUploadComplete: function(file) {
res.send();
}
});
}
Снова, прямо сейчас асинхронный характер node заставляет браузер думать, что загрузка завершена, как только он получает успешный ответ, поэтому, когда я обновляю url для отображения изображения, он отображается только частично. Спасибо за помощь!