Обработка перенаправлений 3xx (HTTP Redirect) средствами 1С

11.11.20

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

Статья описывает способ обработки HTTP ответов с кодом 3хх, говорящих о том, что целевой ресурс переехал по другому адресу.

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

Наименование Файл Версия Размер
HTTP Redirect:
.epf 6,58Kb
4
.epf 6,58Kb 4 Скачать

Статья больше, как памятка для себя. Возникла потребность получать данные файла с таблицей excel (а впрочем неважно какого файла) по ссылке на какой то ресурс на файловом хранилище. В моём случае это был microsoft onedrive, но принципиально это применимо к любому http запросу.

Файлы, хранимые в облаке, можно было опубликовать для анонимного доступа, выдавалась ссылка, в браузере она отлично открывалась, документ сразу же либо открывался, либо скачивался.

Запрос в 1С возвращает ответ с кодом состояния 301 и в теле запроса html код о том, что требуемый ресурс переехал по некоторой ссылке. Грешным делом, сначала возникла мысль получить ДокументDOM из кода html, выдернуть оттуда содержимое href, но потом хватило ума почитать документацию на MDN: Redirections и Location

Для реализации кодом 1С необходимо, получив код состояния 3хх в httpОтвет, выполнить повторый запрос к тому же серверу, но указать путь к ресурсу из заголовка "Location". Так же, в моём случае, первый ответ возвращал токен аутентификации в заголовке "Set-Cookie", его содержимое должно было попасть в заголовок "Cookie" повторного запроса.

Код получился примерно следующий:

Процедура ПрочитатьДанные()
	
        АдресФайла = "Какой то произвольный URL";
	Защита = Новый ЗащищенноеСоединениеOpenSSL(Неопределено, Неопределено);
  	СтруктураУРИ = ОбщегоНазначенияКлиентСервер.СтруктураURI(АдресФайла);
	Попытка
		Соединение = Новый HTTPСоединение(СтруктураУРИ.ИмяСервера, , , , , , Защита);
	Исключение
		Сообщить(ОписаниеОшибки());
	КонецПопытки;
	Запрос = Новый HTTPЗапрос(СтруктураУРИ.ПутьНаСервере);
	Ответ = ОтправитьЗапрос(Соединение, Запрос);
	Если Ответ.КодСостояния = 200 Тогда
                //Как то обрабатываем результат
		//ДД = Ответ.ПолучитьТелоКакДвоичныеДанные();
		//АдресХранилища = ПоместитьВоВременноеХранилище(ДД, Новый УникальныйИдентификатор);
	Иначе
		//Как то обрабатываем ошибку
		АдресХранилища = "";
	КонецЕсли;
КонецПроцедуры

Функция ОбработатьРедирект(Соединение, Ответ)
	//Предполагаем, что если ушли на редирект, то Location точно есть
 	Запрос = Новый HTTPЗапрос(Ответ.Заголовки["Location"]);
	УстановитьПеченьку = Ответ.Заголовки["Set-Cookie"];
        //А вот наличие "Set-Cookie" уже проверяем
	Если НЕ УстановитьПеченьку = Неопределено Тогда
 		Запрос.Заголовки.Вставить("Cookie", УстановитьПеченьку);
	КонецЕсли;
        //Уходим в рекурсию
	Ответ = ОтправитьЗапрос(Соединение, Запрос);
	Возврат Ответ;
	
КонецФункции

&НаСервере
Функция ОтправитьЗапрос(Соединение, Запрос)
	Ответ = Соединение.ВызватьHTTPМетод("GET", Запрос);
	Если Ответ.КодСостояния = 200 Тогда
        //Выходим из рекурсии
		Возврат Ответ;
	ИначеЕсли Ответ.КодСостояния > 300 И Ответ.КодСостояния < 400 Тогда
		//Редирект
		Ответ = ОбработатьРедирект(Соединение, Ответ);
	ИначеЕсли Ответ.КодСостояния >= 400 Тогда
		//Обработка ошибки
		Возврат Ответ;
	КонецЕсли;
	Возврат Ответ;
КонецФункции

Тестировалось на платформе 1С:Предприятие 8.3 (8.3.15.1830).

обработка http

См. также

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

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

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

36000 руб.

03.08.2020    15963    13    18    

13

SALE! 10%

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

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

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

28000 25200 руб.

28.05.2015    84928    28    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    89055    163    216    

319

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

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

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

8400 руб.

01.02.2019    25897    9    0    

7

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

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

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

12000 руб.

02.02.2021    16501    42    49    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. malikov_pro 1293 11.11.20 07:19 Сейчас в теме
2. logos 210 11.11.20 08:54 Сейчас в теме
3. logos 210 11.11.20 08:58 Сейчас в теме
Если честно, всё это имеет мало смысла до тех пор, пока запросы выполняются синхронно. Остаётся надеяться, что в очередной версии платформы подвезут асинхронный http запрос.
5. VVladislav 10.08.22 14:23 Сейчас в теме
(3) завезли же!
HTTPСоединение (HTTPConnection)
ОтправитьДляОбработкиАсинх (PostAsync)
Доступен, начиная с версии 8.3.21.
Синтаксис:
ОтправитьДляОбработкиАсинх(<HTTPЗапрос>, <ИмяВыходногоФайла>)
4. user817897 2 11.11.20 09:25 Сейчас в теме
6. logos 210 11.08.22 13:57 Сейчас в теме
(5) Так когда завезли и когда это было писано
Оставьте свое сообщение