Для загрузки изображений из фотогалереи я настоятельно рекомендую использовать Nativescsript background http . Чтобы загрузить изображения на сервер, вам необходимо сохранить их в приложении, чтобы их можно было загрузить. Я последовал примеру, показанному здесь Загрузить пример .
Если вы сохранили изображения локально, если вам нужны дополнительные данные, вам нужно будет использовать multipartUpload
и создать запрос, который будет выглядеть примерно так:
let BackgroundHTTP = require('nativescript-background-http')
let session = BackgroundHTTP.session('some unique session id')
let request: {
url: 'your.url.to/upload/images',
method: 'POST',
headers: {
'Content-Type': 'application/octet-stream'
}
description: 'Uploading local images to the server'
}
//photos should have at least the filename from when you saved it locally.
let params = []
photos.forEach(photo => {
params.push({name: photo.name, filename: photo.filename, value: 'ANY STRING DATA YOU NEED'})
}
let task = session.multipartUpload(params, request)
task.on('progress', evt => {
console.log('upload progress: ' + ((evt.currentBytes / evt.totalBytes) * 100).toFixed(1) + '%')
}
task.on('error', evt => {
console.log('upload error')
console.log(evt)
}
task.on('complete', evt => {
//this does not mean the server had a positive response
//but the images hit the server.
// use evt.responseCode to determine the status of request
console.log('upload complete, status: ' + evt.responseCode)
}