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

25.02.22

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

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

Скачать исходный код

Наименование Файл Версия Размер
REST API AWS S3 Browser:
.cfe 19,61Kb
66
.cfe 19,61Kb 66 Скачать

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

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

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

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

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

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

 

 

aws s3 bucket

См. также

Интеграция Альфа Авто 5 / Альфа Авто 6 и AUTOCRM / Инфотек

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

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

36000 руб.

03.08.2020    15968    13    18    

13

Интеграция 1С — Битрикс24. Обмен задачами

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

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

5040 руб.

04.05.2021    17960    9    15    

12

SALE! 10%

Автоматическая загрузка файлов (например, прайс-листов) из электронной почты, FTP, HTTP, их обработка и выгрузка на FTP (на сайт) и для других целей

Прайсы WEB-интеграция Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Автомобили, автосервисы Оптовая торговля, дистрибуция, логистика Управленческий учет Платные (руб)

Программа с заданным интервалом времени (или по ручной команде) скачивает файлы (например, прайс-листы поставщиков) из различных источников: письма электронной почты, FTP или HTTP-адреса, и сохраняет их в каталог упорядоченной структуры. При этом извлекает файлы из архивов, может переименовывать файлы и менять их формат (csv, xls, txt). Можно настроить выгрузку обработанных файлов на сайт (через FTP-подключение). Программа будет полезна компаниям, у которых есть большое количество поставщиков и/или прайс-листы поставщиков обновляются часто (необязательно прайс-листы, файлы могут быть любого назначения). Собранные таким образом актуальные версии прайс-листов можно выгрузить с помощью программы себе на сайт (или на любой FTP-сервер) или выполнить другие необходимые задачи.

28000 25200 руб.

28.05.2015    84948    26    51    

50

Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС

Обмен с ГосИС WEB-интеграция Платформа 1С v8.3 Управляемые формы 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия государственного учреждения 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Обработка является альтернативой механизму, разработанному фирмой 1С и заполняющему реквизиты контрагента по ИНН или наименованию. Не требуется действующей подписки ИТС. Вызывается как внешняя дополнительная обработка, т.е. используется, непосредственно, из карточки контрагента. Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС (egrul.nalog.ru) для БП 2.0, БП 3.0, БГУ 1.0, БГУ 2.0, УТ 10.3, УТ 11.x, КА 1.1, КА 2.x, УПП 1.x, ERP 2.x, УНФ 1.5, УНФ 1.6, УНФ 3.0, ДО 2.1

2400 руб.

28.04.2016    89089    163    216    

319

[Расширение] БОР-Навигатор.Культура

Зарплата Бюджетный учет WEB-интеграция Обмен с ГосИС Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бюджетный учет Платные (руб)

Расширение конфигурации, включающее в себя объекты, необходимые для подготовки и сдачи отчета "Штатная численность" системы "БОР-Навигатор.Культура" в программе "1С:Зарплата и кадры государственного учреждения", редакция 3.1.

8400 руб.

01.02.2019    25899    9    0    

7
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. NikeeNik 74 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 74 22.06.23 13:47 Сейчас в теме
(4) присвоил contentType не пустое значение, насколько я помню
2. medangel 83 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 17 18.06.23 20:44 Сейчас в теме
(2)2023 в Амазон поменяли авторизацию через API.
6. M_I_V_91 13.09.23 13:09 Сейчас в теме
(3) Не подскажете, что именно изменилось?
7. fatman78 17 13.09.23 14:47 Сейчас в теме
(6) Много чего, не помню уже - дело было в начале 2023 года. Руки не доходят обработку выложить на Инфостарт.
8. M_I_V_91 14.09.23 15:06 Сейчас в теме
(7) А где с этими изменениями можно ознакомится, не дадите ссылку?
9. fatman78 17 14.09.23 16:37 Сейчас в теме
(8) Это все описано в документации AWS, но она содержала неточности и имела "пробелы" на момент моей работы с ней. И вроде нужна была действующая учетка для доступа к ней...
10. M_I_V_91 15.09.23 09:03 Сейчас в теме
11. Aleksey.Bochkov 3661 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 3661 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 3661 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 857 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;
Оставьте свое сообщение