Удобная отправка HTTP(s) POST запроса

04.11.14

Разработка - Универсальные функции

Удобная отправка HTTP/HTTPS POST запроса с параметрами и передачей файла.
Используется UTF-8 и application/x-www-form-urlencoded и multipart/form-data кодирование.

Файлы

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

Наименование Скачано Купить файл
HTTPЗапрос1С8.x
.epf 11,73Kb ver:1.0
64 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Когда мне потребовалось отправить HTTP/HTTPS POST запрос с параметрами и передачей файла, подходящего и удобного средства не нашел. Пришлось написать небольшой модуль, который, возможно, пригодится кому-нибудь еще.

Есть аналогичный модуль для 1Cv7.7 через MSXML.XMLHTTPRequest, но без поддержки файлов, подготовлю чуть позже.

Для начала требуется получить структуру, описывающую куда и как будем подключаться, функцией РазбитьУРЛ(), возможно дозаполнить свойства.
Далее требуется заполнить соответствия для передачи GET/POST параметров и файлов и вызвать ОтправитьЗапрос()

//Создает структуру и заполняет на основании URL
//Параметры: //Протокол - HTTP или HTTPS
//Порт - по умолчанию 80 для HTTP и 443 для HTTPS
//Безопасное - если протокол HTTPS
//Сервер - имя сервера
//Путь - путь к скрипту/странице на сервере
//СерверИПуть - адрес обращения вида www.server.ru/path/to/query.php
//Пользователь - имя пользователя для Basic авторизации на сайте
//Пароль - пароль пользователя для Basic авторизации
//
//Урл должен быть строкой вида [Протокол://][Пользователь:Пароль@]Сервер[:порт][/Путь]
//Примеры:
//https://server.ru:4001/path/script.php
//http://username:password@server.ru
Функция РазбитьУРЛ(знач урл) Экспорт

//Адрес - структура, которую возвращает функция РазбитьУРЛ()
//_Прокси - опциональные параметры для использования прокси-сервера
// Параметры структуры Прокси
//  РежимПрокси - число:
//   0 - не использовать прокси
//   1 - использовать системные установки (по умолчанию)
//   2 - использовать явные настройки прокси
// Пользователь - имя пользователя прокси-сервера
// Пароль - пароль пользователя прокси-сервера
// Сервер - адрес прокси-сервера. Возможно указание порта как сервер:порт
//ГетПараметры,ПостПараметры,Файлы - Соответствия, где Ключ - имя параметра как оно будет передано, Значение - значение параметра или имя файла для передачи
//УдалятьФайлы (булево) - удалять файлы из набора Файлы после передачи. По умолчанию не удалять.
Функция ОтправитьЗапрос(Адрес,знач _Прокси=Неопределено,ГетПараметры=Неопределено,ПостПараметры=Неопределено,Файлы=Неопределено,УдалятьФайлы=Ложь) Экспорт

Возвращает функция структуру со свойствами:
Ошибка - описание ошибки или Неопределено в случае успеха
Ответ - имя временного файла, содержащего ответ сервера. Разработчик должен сам позаботиться о его удалении
Инет - объект HTTPСоединение, который использовался для запроса

Дополнительно:
Функция U2UTF8(стр)
Кодирует строку в UTF-8, возвращая массив байт

Попутно столкнулся с интересной задачей: требуется писать в текстовый файл в кодировке UTF-8, но без BOM-заголовка. Решение: создаем файл в кодировке ANSI, сразу закрываем и открываем на дозапись в UTF-8:

  Текст=Новый ЗаписьТекста(ВхИмя,КодировкаТекста.ANSI);
  Текст.Закрыть();
  Текст=Новый ЗаписьТекста(ВхИмя,КодировкаТекста.UTF8,,Истина);

Вступайте в нашу телеграмм-группу Инфостарт

HTTP HTTPS интернет POST multipart/form-data

См. также

Загрузка и выгрузка в Excel Универсальные функции Программист 1С:Предприятие 8 Россия Бесплатно (free)

Описанный ниже подход позволяет в три шага заполнять формулы в Excel файлы, вне зависимости от ОС сервера (MS Windows Server или Linux). Подход подразумевает отказ от работы с COM-объектом в пользу работы через "объектную модель документа" (DOM).

30.10.2025    4127    Abysswalker    10    

46

Универсальные функции Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

Порой необходимо временно отключить расширение 1С, не удаляя его, чтобы не потерять данные. Но в этом случае при каждом запуске всем будет лезть уведомление о неактивном расширении, хотя очевидно, это техническая информация, которой не стоит лишний раз пугать пользователей.

14.05.2025    7685    DeerCven    15    

61

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    52711    dimanich70    84    

174

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    7674    7    John_d    13    

59

Универсальные функции Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    67182    atdonya    31    

72

Универсальные функции Программист 1С:Предприятие 8 Бесплатно (free)

На заключительных этапах, когда идет отладка или доработка интерфейса, необходимо много раз переоткрыть внешний объект. Вот один из способов автоматизации этого.

30.11.2023    9605    ke.92@mail.ru    17    

68
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Иной 09.11.14 00:01 Сейчас в теме
Сохранил.

А примера получения ответа (файла) на реквест у Вас нету?
2. Pasha1st 864 09.11.14 00:21 Сейчас в теме
Собственно в обработке есть классическая форма, отправляющая запрос и выводящая ответ. Весь код процедуры-примера использования на скриншоте. Что-нибудь требуется прокомментировать подробнее?
Для отправки сообщения требуется регистрация/авторизация