Инициализировать загрузку частями
Инициализирует загрузку объекта по частям
- Параметры
- Расширенный вызов ?
Функция ИнициализироватьЗагрузкуЧастями(Знач Наименование, Знач Бакет, Знач ОсновныеДанные, Знач Заголовки = Неопределено, Знач Каталог = Ложь) Экспорт
| Параметр | CLI опция | Тип | Обяз. | Назначение |
|---|---|---|---|---|
| Наименование | --name | Строка | ✔ | Наименование объекта в бакете |
| Бакет | --bucket | Строка | ✔ | Имя бакета для загрузки объекта |
| ОсновныеДанные | --basic | Структура Из КлючИЗначение | ✔ | Основные данные запроса. См. ПолучитьСтруктуруДанных |
| Заголовки | --headers | Соответствие Из КлючИЗначение | ✖ | Дополнительные заголовки запроса, если необходимо |
| Каталог | --dir | Булево | ✖ | Истина > Path style URL, Ложь > Virtual hosted style URL |
Возвращаемое значение
Структура Из КлючИЗначение - сериализованный JSON ответа от хранилища
| Параметр | Описание |
|---|---|
| proxy | ИнтернетПрокси или структура полей Протокол, Сервер, Порт, Пользователь, Пароль, ИспользоватьАутентификациюОС |
| timeout | Таймаут выполнения запроса |
| adv_response | Оформляет ответ в виде полной структуры с полями code, body и headers |
подсказка
Метод в документации AWS: CreateMultipartUpload
Это служебный метод. Для простого сценария загрузки файл ов предназначен единый метод ЗагрузитьОбъект
Использование загрузки частями для файлов < 5 МБ или при размере одной части < 5 МБ приведет к ошибке
Пример использования для 1С:Предприятие/OneScript
URL = "s3.openintegrations.dev";
AccessKey = "bayselo...";
SecretKey = "12we34...";
Region = "BTC";
ОсновныеДанные = OPI_S3.ПолучитьСтруктуруДанных(URL, AccessKey, SecretKey, Region);
Наименование = "fileChunked.mp3";
Каталог = Истина; // Формирование URL в path-style
Бакет = "w567hjy1";
Содержимое = "https://hut.openintegrations.dev/test_data/song.mp3"; // URL, Путь или Двоичные данные
Содержимое = OPI_ЗапросыHTTP.Get(Содержимое);
Результат = OPI_S3.ИнициализироватьЗагрузкуЧастями(Наименование, Бакет, ОсновныеДанные, , Каталог);
// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
IDЗагрузки = Результат["response"]["InitiateMultipartUploadResult"]["UploadId"];
ОбщийРазмер = Содержимое.Размер();
РазмерУчастка = 5242880;
ПрочитаноБайт = 0;
НомерЧасти = 1;
ЧтениеДанных = Новый ЧтениеДанных(Содержимое);
ИсходныйПоток = ЧтениеДанных.ИсходныйПоток();
МассивТегов = Новый Массив;
Пока ПрочитаноБайт < ОбщийРазмер Цикл
ТекущееЧтение = ЧтениеДанных.Прочитать(РазмерУчастка);
ТекущиеДанные = ТекущееЧтение.ПолучитьДвоичныеДанные();
Если ТекущиеДанные.Размер() = 0 Тогда
Прервать;
КонецЕсли;
Результат = OPI_S3.ЗагрузитьЧастьОбъекта(Наименование
, Бакет
, ОсновныеДанные
, IDЗагрузки
, НомерЧасти
, ТекущиеДанные
, Каталог);
ПрочитаноБайт = ИсходныйПоток.ТекущаяПозиция();
ETag = Результат["headers"]["Etag"];
ETag = ?(ETag = Неопределено, Результат["headers"]["ETag"], ETag);
МассивТегов.Добавить(ETag);
НомерЧасти = НомерЧасти + 1;
КонецЦикла;
Результат = OPI_S3.ЗавершитьЗагрузкуЧастями(Наименование, Бакет, ОсновныеДанные, IDЗагрузки, МассивТегов, , Каталог);
- Bash
- CMD/Bat
# JSON данные также могут быть переданы как путь к файлу .json
oint s3 ИнициализироватьЗагрузкуЧастями \
--name "fileChunked.mp3" \
--bucket "161317b8" \
--basic "{'URL':'s3.openintegrations.dev','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" \
--dir true
:: JSON данные также могут быть переданы как путь к файлу .json
oint s3 ИнициализироватьЗагрузкуЧастями ^
--name "fileChunked.mp3" ^
--bucket "161317b8" ^
--basic "{'URL':'s3.openintegrations.dev','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" ^
--dir true
Результат
{
"status": 200,
"response": {
"InitiateMultipartUploadResult": {
"Bucket": "60091bf6",
"Key": "***",
"UploadId": "MGI2Y2U2YTAtMDYxZC00NzkwLTk3YmEtOTM0NDY2MWFjZGYwLmNmM2JlMDUzLWZiYjktNDlhZC1iOTU1LWE2OWMxYzMyNzYzMngx..."
}
},
"headers": {
"Accept-Ranges": "bytes",
"Vary": "Accept-Encoding",
"Server": "Microsoft-IIS/10.0",
"Strict-Transport-Security": "max-age=31536000; includeSubDomains",
"X-Amz-Id-2": "dd9025bab4ad464b049177c95eb6ebf374d3b3fd1af9251148b658df7ac2e3e8",
"X-Amz-Request-Id": "18ABB6A70CB5F87B",
"X-Content-Type-Options": "nosniff",
"X-Ratelimit-Limit": "6420",
"X-Ratelimit-Remaining": "6420",
"X-XSS-Protection": "1; mode=block",
"X-Powered-By": "ARR/3.0",
"Date": "Sat, 02 May 2026 09:48:26 GMT",
"Content-Type": "application/xml",
"Content-Length": "346"
}
}