Проблемы с загрузкой изображений с FileTransfer
Я пытаюсь добавить в свое приложение функцию, позволяющую пользователю делать снимки с помощью своей камеры или смартфона, чтобы загрузить их в виде профиля.
Я выбрал эту функцию из другого проекта, который работает отлично, но не от меня, а от одного из моих коллег (он ушел).
Я не знаю почему, так как я использовал точно такую же функцию, но загруженное изображение выглядит так:
Он случайным образом начнет повреждать файл, как правило, в первом квартале. Одно время это работало, но я не могу понять, почему.
takePhoto(value){
const options: CameraOptions = {
quality: 75,
destinationType: this.camera.DestinationType.DATA_URL,
encodingType: this.camera.EncodingType.JPEG,
mediaType: this.camera.MediaType.PICTURE,
correctOrientation : true,
allowEdit:true,
targetWidth: 300,
targetHeight: 300,
sourceType : value
}
this.camera.getPicture(options).then((imageData) => {
// imageData is either a base64 encoded string or a file URI
// If it's base64:
let base64Image = 'data:image/jpeg;base64,' + imageData;
console.log(base64Image)
//$("#imgProfil").attr("src",base64Image);
const fileTransfer: FileTransferObject = this.transfer.create();
this._zone.run(() => {
this.avatar_path = base64Image;
});
var targetPath = base64Image;
var options = {
fileKey: "avatar",
fileName: this.user._id + ".jpg",
chunkedMode: false,
mimeType: "image/jpeg",
headers: {
//Connection: "close"
}
};
fileTransfer.upload(targetPath,"http://XX.XXX.XXX.XX:90/add/photoandroid/" + this.user._id, options) .then((data) => {
this.storage.set('photoProfilData',base64Image);
this.events.publish('photoProfil');
}, (err) => {
})
}, (err) => {
this.presentToasti(err);
});
}
Есть идеи, почему он это делает? О, забыл упомянуть: с версией приложения для iOS загрузка изображений работает отлично, поэтому я не думаю, что проблема связана со свойствами сервера. Приложение iOS использует свою собственную функцию для получения изображения на сервере.
А вот серверная часть:
exports.addphotoandroid = function(req, res){
var ObjectID = require('mongodb').ObjectID;
var fstream;
var monid = req.params.id;
req.pipe(req.busboy);
req.busboy.on('file', function (fieldname, file, filename) {
console.log("Uploading: " + monid + ".jpg");
//Path where image will be uploaded
fstream = fs.createWriteStream("/var/sammy/public/upload/photoprofil/" + monid + ".jpg");
file.pipe(fstream);
fstream.on('close', function () {
console.log("Upload Finished of " + monid + ".jpg");
response = {"succces" : "photo bien uploadée "};
});
});
};
Пытаясь с Салманом Уллой ответить:
POST /add/photoandroid/5a1fd1a89a6f09412b6a74d7 500 28.912 ms - 1426 _stream_readable.js:598
dest.end();
^
TypeError: Cannot read property 'end' of undefined
at IncomingMessage.onend (_stream_readable.js:598:9)
at Object.onceWrapper (events.js:314:30)
at emitNone (events.js:105:13)
at IncomingMessage.emit (events.js:207:7)
at endReadableNT (_stream_readable.js:1059:12)
at _combinedTickCallback (internal/process/next_tick.js:138:11)
at process._tickCallback (internal/process/next_tick.js:180:9)
events.js:182
throw er; // Unhandled 'error' event
^
Error: read ECONNRESET
at _errnoException (util.js:1041:11)
at Pipe.onread (net.js:606:25)
Это ошибка, которую я получаю с сервера.
1 ответ
Попробуйте отправить imageData вместо targetPath.
Как это:
fileTransfer.upload(imageData ,"http://XX.XXX.XXX.XX:90/add/photoandroid/" +
this.user._id, options) .then((data) => {