Завершить загрузку частями
Подтверждает окончание загрузки объекта по частям
Функция ЗавершитьЗагрузкуЧастями(Знач Наименование, Знач Бакет, Знач ОсновныеДанные, Знач IDЗагрузки, Знач МассивТегов, Знач Заголовки = Неопределено) Экспорт
Параметр | CLI опция | Тип | Обяз. | Назначение |
---|---|---|---|---|
Наименование | --name | Строка | ✔ | Наименование объекта в бакете |
Бакет | --bucket | Строка | ✔ | Имя бакета для загрузки объекта |
ОсновныеДанные | --basic | Структура Из КлючИЗначение | ✔ | Основные данные запроса. См. ПолучитьСтруктуруДанных |
IDЗагрузки | --upload | Строка | ✔ | ID загрузки по частям. См. ИнициализироватьЗагрузкуЧастями |
МассивТегов | --tags | Массив Из Строка | ✔ | Массив тегов (Etag) из загрузок каждой части |
Заголовки | --headers | Соответствие Из КлючИЗначение | ✖ | Дополнительные заголовки запроса, если необходимо |
Возвращаемое значение: Структура Из КлючИЗначение - сериализованный JSON ответа от хранилища
подсказка
Метод в документации AWS: CompleteMultipartUpload
Это служебный метод. Для простого сценария загрузки файлов предназначен единый метод ЗагрузитьОбъект
Пример использования для 1С:Предприятие/OneScript
URL = "storage-155.s3hoster.by";
AccessKey = "BRN5RKJE67...";
SecretKey = "NNhv+i9PrytpT8Tu0C1N...";
Region = "BTC";
ОсновныеДанные = OPI_S3.ПолучитьСтруктуруДан ных(URL, AccessKey, SecretKey, Region);
Наименование = "fileChunked.mp3";
Бакет = "opi-gpbucket3";
Содержимое = "https://api.athenaeum.digital/test_data/song.mp3"; // URL, Путь или Двоичные данные
Содержимое = OPI_Инструменты.Get(Содержимое);
Результат = OPI_S3.ИнициализироватьЗагрузкуЧастями(Наименование, Бакет, ОсновныеДанные);
IDЗагрузки = Результат["response"]["InitiateMultipartUploadResult"]["UploadId"];
ОбщийРазмер = Содержимое.Размер();
РазмерУчастка = 5242880;
ПрочитаноБайт = 0;
НомерЧасти = 1;
ЧтениеДанных = Новый ЧтениеДанных(Содержимое);
ИсходныйПоток = ЧтениеДанных.ИсходныйПоток();
МассивТегов = Новый Массив;
Пока ПрочитаноБайт < ОбщийРазмер Цикл
ТекущееЧтение = ЧтениеДанных.Прочитать(РазмерУчастка);
ТекущиеДанные = ТекущееЧтение.ПолучитьДвоичныеДанные();
Если ТекущиеДанные.Размер() = 0 Тогда
Прервать;
КонецЕсли;
Результат = OPI_S3.ЗагрузитьЧастьОбъекта(Наименование
, Бакет
, ОсновныеДанные
, IDЗагрузки
, НомерЧасти
, ТекущиеДанные);
ПрочитаноБайт = ИсходныйПоток.ТекущаяПозиция();
МассивТегов.Добавить(Результат["headers"]["Etag"]);
НомерЧасти = НомерЧасти + 1;
КонецЦикла;
Результат = OPI_S3.ЗавершитьЗагрузкуЧастями(Наименование, Бакет, ОсновныеДанные, IDЗагрузки, МассивТегов);
// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
- Bash
- CMD/Bat
# JSON данные также могут быть переданы как путь к файлу .json
oint s3 ЗавершитьЗагрузкуЧастями \
--name "fileChunked.mp3" \
--bucket "opi-gpbucket3" \
--basic "{'URL':'storage-155.s3hoster.by','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" \
--upload "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjQxYjQxYjFhLWU2MzktNGRmNC1iOTdhLWEzZDhhMzQ2MTQ4Nw" \
--tags "['\"566e2d464b39b91eb8b5d89fb9f1a318\"','\"adb76a9a9ff8226ed08fb6f343102908\"']"
:: JSON данные также могут быть переданы как путь к файлу .json
oint s3 ЗавершитьЗагрузкуЧастями ^
--name "fileChunked.mp3" ^
--bucket "opi-gpbucket3" ^
--basic "{'URL':'storage-155.s3hoster.by','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" ^
--upload "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjQxYjQxYjFhLWU2MzktNGRmNC1iOTdhLWEzZDhhMzQ2MTQ4Nw" ^
--tags "['\"566e2d464b39b91eb8b5d89fb9f1a318\"','\"adb76a9a9ff8226ed08fb6f343102908\"']"
Результат
{
"status": 200,
"response": {
"CompleteMultipartUploadResult": {
"Location": "https://opi-gpbucket3.storage-155.s3hoster.by/fileChunked.mp3",
"Bucket": "opi-gpbucket3",
"Key": "fileChunked.mp3",
"ETag": "\"22c09aeeb42144b375de8a4c1a1bb573-2\""
}
},
"headers": {
"Accept-Ranges": "bytes",
"Content-Length": "345",
"Content-Type": "application/xml",
"Date": "Fri, 22 Nov 2024 09:35:15 GMT",
"Etag": "\"22c09aeeb42144b375de8a4c1a1bb573-2\"",
"Server": "MinIO",
"Strict-Transport-Security": "max-age=31536000; includeSubDomains",
"Vary": "Origin,Accept-Encoding",
"X-Amz-Id-2": "93c576aa54c960b355da9e2934476635fe3243f5df9dbb4db8b7c0d94bec7cd1",
"X-Amz-Request-Id": "180A40AC4B0F3A5F",
"X-Content-Type-Options": "nosniff",
"X-Xss-Protection": "1; mode=block"
}
}