Подключение к DROPBOX через REST API

28.12.17

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

Обработка позволит подключить вашу конфигурацию к диску DROPBOX через публичный REST API сервиса. В ней есть графический интерфейс, поэтому можно проверить работоспособность до встраивания обработки в конфигурацию.

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

Наименование Файл Версия Размер
Подключение к DROPBOX через REST API:
.epf 17,51Kb
15
.epf 1.0.1 17,51Kb 15 Скачать

Возможности

  • OAuth-авторизация
  • Обзор файлов
  • Добавление папок
  • Загрузка файлов на Диск Dropbox
  • Скачивание файлов с Dropbox
  • Удаление файлов и папок

Использование

  1. Зарегистрируйте свое приложение в DROPBOX, включите необходимые права.
  2. Скачайте обработку.
  3. Загрузите обработку в конфигурацию или подключите ее через подсистему дополнительных отчетов и обработок из БСП.
  4. Получите код авторизации в личном кабинете Dropbox.
  5. Используйте процедуру "Токен" из модуля объекта обработки для обмена полученного кода авторизации на OAuth-токен или токен можно сгенерировать в личном кабинете Dropbox.
  6. Используйте программный интерфейс объекта обработки, модуль объекта содержит подробные комментарии.

 

ПРИМЕРЫ ИСПОЛЬЗОВАНИЯ

Инициализация

// Создаем объект из конфигурации

DropBox = Обработки. ОбменDropBox.Создать();

 

// Или создаем объект из подсистемы доп. обработок БСП 2.3

DropBox = ДополнительныеОтчетыИОбработки.ОбъектВнешнейОбработки(СсылкаНаДопОбработку);

 

DropBox.IDПриложения = Константы.IDПриложенияDropBox.Получить();

DropBox.ПарольПриложения = Константы.ПарольПриложенияDropBox.Получить();

DropBox.Токен = Константы.ТокенDropBox.Получить();

 

Просмотр и скачивание файлов

// Получаем список файлов

DropBox.СписокФайлов();

 

// Скачиваем файл

АдресФайла = DropBox.СкачатьФайл(РасположениеНаДискеDropbox);

ДанныеФайла = ПолучитьИзВременногоХранилища(АдресФайла);

ДанныеФайла.Записать(ВременныйФайл);

 

// остальные методы по аналогии

Особенности

  • Для работы нужна версия платформы 8.3.6.1977 и выше.
  • Используются кроссплатформенные объекты для работы с HTTP запросами, так что должно работать на Linux и Mac.

Т.к. не было найдено готового решения здесь, принял, как шаблон удачного примера Классный пример для Яндекса и реализовал только для сервиса Dropbox.

 

Спасибо, что дочитали до конца!

REST DROPBOX

См. также

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

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

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

36000 руб.

03.08.2020    16104    13    18    

13

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

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

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

5040 руб.

04.05.2021    18203    10    15    

16

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

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

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

25200 руб.

28.05.2015    85453    26    51    

50

Модуль для обмена "1С:Предприятие 8. УАТ. ПРОФ" с FortMonitor

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

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

22656 руб.

25.05.2021    13006    33    8    

12

Интеграция с сервисом vetmanager

WEB-интеграция Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бытовые услуги, сервис Платные (руб)

Внешняя обработка разрабатывалась для загрузки документов из Ветменеджер в 1С: Бухгалтерия 3.0

12000 руб.

02.02.2021    16641    43    49    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Dzenn 875 19.10.18 11:44 Сейчас в теме
Спасибо огромное за обработку! Она прекрасна, и очень помогла, но есть нюанс:

Вместо конструкций вида

	Заголовки.Вставить("Dropbox-API-Arg", "{""path"": " + """" + Путь + """" + "}");


надо использовать

	ПЗ = Новый ПараметрыЗаписиJSON(ПереносСтрокJSON.Нет,,,ЭкранированиеСимволовJSON.СимволыВнеASCII);
	ЗД = Новый ЗаписьJSON;
	ЗД.УстановитьСтроку(ПЗ);
	ЗД.ЗаписатьНачалоОбъекта();
	ЗД.ЗаписатьИмяСвойства("path");
	ЗД.ЗаписатьЗначение(Путь);
	ЗД.ЗаписатьКонецОбъекта();
	Аргументы = ЗД.Закрыть();

	Заголовки.Вставить("Dropbox-API-Arg", Аргументы);
Показать


Это позволяет использовать кириллицу в именах файлов и гарантирует валидность JSON в любых других случаях.
men260181; acanta; +2 Ответить
2. men260181 22 19.10.18 15:37 Сейчас в теме
(1) Спасибо, приятель! Отличное дополнение, нет предела совершенству :)
3. Dzenn 875 19.10.18 15:39 Сейчас в теме
(2) пожалуйста ;-)
И ещё не хватило обработки параметра "Перезапись" в процедуре ЗагрузитьФайл(...)

Процедура ЗагрузитьФайл(Знач Путь, Знач АдресХранилища, Знач Перезаписывать = Ложь) Экспорт
		
	ИмяСервера = "content.dropboxapi.com";
	ОтносительныйURL = "/2/files/upload";
	
	Заголовки = СформироватьЗаголовки();
	
	Если Перезаписывать Тогда
		Перезапись = "overwrite";
	Иначе
		Перезапись = "add";
	КонецЕсли;
	
	ПЗ = Новый ПараметрыЗаписиJSON(ПереносСтрокJSON.Нет,,,ЭкранированиеСимволовJSON.СимволыВнеASCII);
	ЗД = Новый ЗаписьJSON;
	ЗД.УстановитьСтроку(ПЗ);
	ЗД.ЗаписатьНачалоОбъекта();
	ЗД.ЗаписатьИмяСвойства("path");
	ЗД.ЗаписатьЗначение(Путь);
	ЗД.ЗаписатьИмяСвойства("mode");
	ЗД.ЗаписатьЗначение(Перезапись);
	ЗД.ЗаписатьКонецОбъекта();
	Аргументы = ЗД.Закрыть();
	
	Заголовки.Вставить("Authorization", "Bearer " + Токен);
	Заголовки.Вставить("Dropbox-API-Arg", Аргументы);
	Заголовки.Вставить("Content-Type", "application/octet-stream");
	Заголовки.Вставить("Accept", "application/octet-stream");
	
	HttpЗапрос = Новый HTTPЗапрос(ОтносительныйURL, Заголовки);
	HttpЗапрос.УстановитьТелоИзДвоичныхДанных(ПолучитьИзВременногоХранилища(АдресХранилища));
	
	HttpСоединение = Новый HTTPСоединение(ИмяСервера, 443,,,,, Новый ЗащищенноеСоединениеOpenSSL);
	HttpОтвет = HttpСоединение.ОтправитьДляОбработки(HTTPЗапрос, "");

	ТелоОтвета = HttpОтвет.ПолучитьТелоКакСтроку(КодировкаТекста.UTF8);
	ОбработатьКодСостояния(HttpОтвет, ОтносительныйURL, ТелоОтвета);
	
	Чтение = Новый ЧтениеJSON;
	Чтение.УстановитьСтроку(ТелоОтвета);
	Ответ = ФабрикаXDTO.ПрочитатьJSON(Чтение);
	
КонецПроцедуры

Показать
4. user1432682 14.08.20 21:01 Сейчас в теме
Добрый день. ПОдскажите пожалуйста, как в форму список фалов загнать более 500. всю голову сломал:(
5. men260181 22 23.09.20 06:52 Сейчас в теме
Можно вызвать эту процедуру циклом по количеству файлов. Можно передать пути к файлам массивом, а в процедуре (переделать) циклом для каждого выполнить нужные действия.
Оставьте свое сообщение