REST API AWS S3 Browser - пример интеграции 1С и AWS S3 средствами платформы

25.02.22

Интеграция - WEB-интеграция

Пример работы с S3 средствами 1С через REST API - без внешних компонент, SDK или CLI.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
REST API AWS S3 Browser:
.cfe 19,61Kb
78
78 Скачать (1 SM) Купить за 1 850 руб.

Минимальная версия платформы: 8.3.18.

Расширение конфигурации, демонстрирующее работу с AWS S3 через REST API средствами 1С без использования внешных компонент, SDK или CLI. HTTP запросы аутентифицируются с использованием AWS Signature Version 4.
Это прототип, а не готовое решение.

Поддерживаемые операции:

  • Показать Список Объектов - выполоняется единственный запрос, возвращающий до "Max Keys Per Request" ключей (без рекурсии для больших списков).
  • Создать Новый Каталог - добавить пустой ключ для обозначения каталога*.
  • Добавить Новый Файл - добавить новый файл в текущий каталог*
  • Удалить Файл - удалить выделенный объект

*(в S3 нет понятия каталогов - это упрощение)

Исходный код в GitHub

 

 

aws s3 bucket

См. также

Сайты и интернет-магазины WEB-интеграция Системный администратор Программист Пользователь Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM разных брендов в одной информационной базе в ручном и автоматическом режиме.

36000 руб.

03.08.2020    17783    19    22    

16

Сайты и интернет-магазины Интеграция WEB-интеграция Платформа 1С v8.3 Конфигурации 1cv8 Управленческий учет Платные (руб)

Интеграция 1С и Битрикс 24. Разработка имеет двухстороннюю синхронизацию 1С и Bitrix24 задачами. Решение позволяет создавать пользователя в 1С из Битрикс24 и наоборот. Данная разработка технически подходит под все основные конфигурации линейки продуктов 1С:Предприятие 8.3 (платформа начиная с 8.3.23). При приобретении предоставляется 1 месяц бесплатных обновлений разработки. Доступна демо-версия продукта с подключением Вашего Битрикс24

5040 руб.

04.05.2021    19849    13    17    

16

WEB-интеграция 8.3.8 Конфигурации 1cv8 Автомобили, автосервисы Беларусь Украина Россия Казахстан Управленческий учет Платные (руб)

Расширение предназначено для конфигурации "1С:Предприятие 8. Управление Автотранспортом. ПРОФ". Функционал модуля: 1. Заполнение регистров сведений по подсистеме "Мониторинг", а именно: события по мониторингу, координаты по мониторингу, пробег и расход по мониторингу, текущее местоположение ТС по мониторингу 2. Заполнение путевого листа: пробег по мониторингу, время выезда/заезда, табличная часть ГСМ, места стоянок по геозонам. 3. Отчеты по данным загруженным в регистры сведений. 4. Предусмотрена автоматическая загрузка данных в фоновом режиме (условия работы данной загрузке читайте в описании товара) Модуль работает без включенной константы по настройкам мониторинга. Модуль формы предоставляется с открытым кодом, общий модуль защищен. Любой заинтересованный пользователь, имеет возможность скачать демо-версию расширения.

22656 руб.

25.05.2021    14424    42    8    

18

WEB-интеграция Программист Руководитель проекта Платформа 1С v8.3 Конфигурации 1cv8 1С:Франчайзи, автоматизация бизнеса Платные (руб)

Расширение значительно упрощает написание API на 1С. Веб программисты получают простой и понятный доступ к 1С. Описание API создаётся автоматически и представляется в виде удобном как для человека, так и для программной обработки.

24000 руб.

27.09.2024    1172    1    0    

3
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. NikeeNik 79 29.06.22 23:08 Сейчас в теме
Отличная штука. Спасибо! Очень помогла в разборках с Minio.
Но есть там один косячок - при формировании canonical request используется заголовок "contentType", которому присвоена пустая строка, потом этот заголовок вставляется в http-запрос, а 1С видит что он пустой и выкидывает его. В итоге сервис смотрит в строку авторизации где заголовок "contentType" указан в подразделе "SignedHeaders", смотрит в пришедший запрос и такого заголовка там не видит и отдает ошибку: 400: "There were headers present in the request which were not signed".
Ну и почему-то с параметрами запроса (query string parameters) у меня не взлетело, возможно особенность Minio.
Aspire1C; +1 Ответить
4. Bronnikoff 21.06.23 19:54 Сейчас в теме
(1)Как смогли обойти эту ошибку?
5. NikeeNik 79 22.06.23 13:47 Сейчас в теме
(4) присвоил contentType не пустое значение, насколько я помню
2. medangel 84 29.04.23 13:07 Сейчас в теме
При использовании выдает ошибку:
The request signature we calculated does not match the signature you provided. Check your key and signing method.
3. fatman78 20 18.06.23 20:44 Сейчас в теме
(2)2023 в Амазон поменяли авторизацию через API.
6. M_I_V_91 13.09.23 13:09 Сейчас в теме
(3) Не подскажете, что именно изменилось?
7. fatman78 20 13.09.23 14:47 Сейчас в теме
(6) Много чего, не помню уже - дело было в начале 2023 года. Руки не доходят обработку выложить на Инфостарт.
8. M_I_V_91 14.09.23 15:06 Сейчас в теме
(7) А где с этими изменениями можно ознакомится, не дадите ссылку?
9. fatman78 20 14.09.23 16:37 Сейчас в теме
(8) Это все описано в документации AWS, но она содержала неточности и имела "пробелы" на момент моей работы с ней. И вроде нужна была действующая учетка для доступа к ней...
10. M_I_V_91 15.09.23 09:03 Сейчас в теме
11. Aleksey.Bochkov 3681 13.10.23 00:03 Сейчас в теме
(2)
The request signature we calculated does not match the signature you provided. Check your key and signing method.

странно, у меня прежний код все еще работает.
12. Rif_md 6 07.11.23 00:37 Сейчас в теме
Отличная разработка! Спасибо! Такой вопрос - на основании какой документации настроен такой алгоритм?
Я обращался к стандартной документации
https://docs.aws.amazon.com/AmazonS3/latest/API/API_PutObject.html
но не смог найти нечто похожее на точно такую последовательность действий.
13. Aleksey.Bochkov 3681 07.11.23 15:44 Сейчас в теме
(12) код был написан на основе работающего .NET примера.. просто от скуки на самом деле.
Я бы не рекомендовал использовать что-то подобное в реальной системе, т.к. поддерживать такой протокол интеграции довольно сложно.
Более правильным вариантом, как мне кажется, было бы использование Python - сделать минимальные функции на Flask, завернуть в Docker и не беспокоиться по поводу изменения протокола интеграции или авторизации на стороне AWS. Я хочу добавлю такой пример на GitHub в скором времени.
14. Rif_md 6 07.11.23 19:33 Сейчас в теме
(13) И как такая схема будет интегрироваться с 1С? На самом деле пример рабочий, с Minio отрабатывает отлично. Я чуть оптимизировал код, чтоб передаваемый файл не сохранялся как внешний. Можно сразу использовать адрес внешнего хранилища, а тело запроса заполнить из двоичных данных.
15. Aleksey.Bochkov 3681 07.11.23 22:58 Сейчас в теме
(14) через обычные HTTP запросы (ну или через COM попробовать как тут описано https://infostart.ru/1c/tools/1943747/ ) - 1С вызывает простые запросы в Python прослойке, а Python уже использует официальные библиотеки для работы AWS S3 / Azure Blob Storage / любые другие целевые системы.
Сильно проще, чем поддерживать низкоуровневую REST интеграцию напрямую с S3.

В этом примере операций то особо нет. Если начать усложнять операциями типа фильтрации по тегам, или получения публичной подписанной ссылки, или права доступа отдельные, то IMHO неоправданно сложно получается.
16. Rus1k 15 29.02.24 16:44 Сейчас в теме
А как можно получить двоичные данные из S3?
17. Aspire1C 869 11.03.24 10:08 Сейчас в теме
на min.io взлетело и с таким кодом, единственное пришлось поправить, в процедуре:

&AtServer
Procedure ExecuteCommand(Command, CurrentPrefix, LocalFilePath = Undefined, FileContentType = Undefined)
...
contentType = "application/json";
...
queryParams = "list-type=2&max-keys=" + Object.MaxKeysPerRequest;
uri = AbsolutePath + "?list-type=2&max-keys=" + Object.MaxKeysPerRequest;
Оставьте свое сообщение