Добавить лид с файлами через веб-форму
Scope:
crmКто может выполнять метод: пользователи с правом создания лидов в CRM
Если вы разрабатываете интеграции для Битрикс24 с помощью AI-инструментов (Codex, Claude Code, Cursor), подключите MCP-сервер, чтобы ассистент использовал официальную REST-документацию.
На сайте можно разместить форму для сбора данных потенциальных клиентов. Когда клиент заполнит форму и приложит файлы, его данные попадут в CRM, и вы сможете обработать заявку.
Настройка формы состоит из двух шагов.
-
Разместите форму на HTML-странице. Она отправит данные в обработчик.
-
Создайте файл для обработки данных. Обработчик примет и подготовит данные, а затем создаст лид методом crm.lead.add.
1. Создаем веб-форму
В Битрикс24 из лида можно автоматически создать контакт и компанию. Чтобы форма подходила для разных случаев, сделаем ее универсальной. Для контакта нужно указать имя и фамилию, а для компании — название. Создадим на странице сайта веб-форму с полями:
-
NAME— имя, обязательное, -
LAST_NAME— фамилия, -
COMPANY_TITLE— название компании, -
EMAIL— электронная почта, -
PHONE— телефон.
Чтобы клиент мог загрузить файлы, добавим в форму поля:
-
FILE— для одного файла, -
FILES— для добавления нескольких файлов.
При отправке форма передает данные в обработчик form.php.
<form id="form_to_crm" method="POST" action="form.php" enctype="multipart/form-data">
<!-- Имя (обязательное поле) -->
<input type="text" name="NAME" placeholder="Имя" required>
<!-- Фамилия -->
<input type="text" name="LAST_NAME" placeholder="Фамилия">
<!-- Название компании -->
<input type="text" name="COMPANY_TITLE" placeholder="Название компании">
<!-- Email -->
<input type="text" name="EMAIL" placeholder="Почта">
<!-- Телефон -->
<input type="text" name="PHONE" placeholder="Телефон">
<!-- Поле для одного файла -->
<input type="file" name="FILE">
<!-- Поле для нескольких файлов -->
<input type="file" name="FILES" multiple">
<!-- Кнопка отправки -->
<input type="submit" value="Отправить">
</form>
<!-- Подключаем jQuery для AJAX-запроса -->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script>
$(document).ready(function() {
$('#form_to_crm').on('submit', function(el) {
el.preventDefault();
var formData = new FormData(this); // Собираем данные формы с файлами
$.ajax({
method: 'POST',
url: 'form.php',
data: formData,
processData: false,
contentType: false,
dataType: 'json',
success: function(data) {
alert(data.message);
},
error: function() {
alert('Ошибка при отправке формы');
}
});
});
});
</script>
2. Создаем обработчик формы
Чтобы обработать значения из полей формы и добавить лид в CRM, создадим обработчик form.php.
Подготавливаем данные из формы
Чтобы использовать данные из формы в методе создания лида, нужно их подготовить.
Очищаем от HTML-тегов
Получаем и очищаем от HTML-тегов данные из формы.
// Получаем и очищаем данные из формы
$sName = htmlspecialchars($_POST["NAME"]);
$sLastName = htmlspecialchars($_POST["LAST_NAME"]);
$sCompanyTitle = htmlspecialchars($_POST["COMPANY_TITLE"]);
$sPhone = htmlspecialchars($_POST["PHONE"]);
$sEmail = htmlspecialchars($_POST["EMAIL"]);
Подготавливаем файлы
Подготавливаем файлы для загрузки в Битрикс24. Для каждого файла нужно передать массив:
-
с именем файла,
-
строкой с кодировкой файла в Base64.
Чтобы закодировать файл, используем функцию base64_encode.
Документация
// Создаем переменные для массивов с файлами
$arFiles = [];
$arSingleFile = [];
// Обрабатываем поле FILES с несколькими файлами
if(!empty($_FILES['FILES']['tmp_name'])) {
foreach($_FILES['FILES']['tmp_name'] as $key => $tmpName) {
if(!empty($tmpName)) {
$arFiles[] = [
'fileData' => [
$_FILES['FILES']['name'][$key], // название файла
base64_encode(file_get_contents($tmpName)) // контент файла, закодированный в base64
]
];
}
}
}
// Обрабатываем поле FILE с одним файлом
if(!empty($_FILES['FILE']['tmp_name'])) {
$arSingleFile = [
'fileData' => [
$_FILES['FILE']['name'], // название файла
base64_encode(file_get_contents($_FILES['FILE']['tmp_name'])) // контент файла, закодированный в base64
]
];
}
Форматируем телефон и почту
Телефон и email система хранит как массив объектов crm_multifield, поэтому их нужно привести к формату массива.
-
Если значение есть, добавляем его первым элементом
VALUEв массив, а вторым значением указываем типVALUE_TYPE, например:-
WORK— для телефона, -
HOME— для email.
-
-
Если значения нет, передаем пустой массив.
// Форматируем телефон и почту для Битрикс24 в формат crm_multifield
$arPhone = (!empty($sPhone)) ? array(array('VALUE' => $sPhone, 'VALUE_TYPE' => 'WORK')) : array();
$arEmail = (!empty($sEmail)) ? array(array('VALUE' => $sEmail, 'VALUE_TYPE' => 'HOME')) : array();
Формируем заголовок лида
Заголовок лида сформируем из имени и фамилии. Для компаний добавим в заголовок название компании.
// Формируем заголовок лида из имени и фамилии
$sTitle = 'С сайта: ' . trim($sName . ' ' . $sLastName);
// Если есть название компании — добавляем его через тире после имени и фамилии
if (!empty($sCompanyTitle)) {
$sTitle .= ' — ' . $sCompanyTitle;
}
Создаем лид
Для создания лида используем метод crm.lead.add. В объекте fields передаем поля:
-
TITLE— заголовок лида, -
NAME— имя лида, -
LAST_NAME— фамилия, -
COMPANY_TITLE— название компании, -
PHONE— номер телефона, -
EMAIL— электронная почта, -
UF_CRM_LEAD_FILES— пользовательское поле для добавления нескольких файлов, -
UF_CRM_LEAD_FILE— пользовательское поле для файла.
Пользовательские поля UF_CRM_* нужно создать в Битрикс24 до создания лида. Добавьте их на портале вручную или методом crm.lead.userfield.add. В примере подставьте свои названия полей вместо UF_CRM_LEAD_FILES и UF_CRM_LEAD_FILE.
Проверьте, какие обязательные поля настроены для лидов в вашем Битрикс24. Все обязательные поля нужно передать в метод crm.lead.add.
CRest::call(
'crm.lead.add',
[
'fields' => [
'TITLE' => $sTitle, // Заголовок лида
'NAME' => $sName, // Имя
'LAST_NAME' => $sLastName, // Фамилия
'COMPANY_TITLE' => $sCompanyTitle, // Название компании
'PHONE' => $arPhone, // Телефон
'EMAIL' => $arEmail, // Email
'UF_CRM_LEAD_FILES' => $arFiles, // Поле для добавления нескольких файлов
'UF_CRM_LEAD_FILE' => $arSingleFile // Поле для файла
]
]
);
В результате получим идентификатор нового лида 5.
{
"result": 5
}
Полный пример кода обработчика
<?
require_once('crest.php');
// Получаем и очищаем данные из формы
$sName = htmlspecialchars($_POST["NAME"]);
$sLastName = htmlspecialchars($_POST["LAST_NAME"]);
$sCompanyTitle = htmlspecialchars($_POST["COMPANY_TITLE"]);
$sPhone = htmlspecialchars($_POST["PHONE"]);
$sEmail = htmlspecialchars($_POST["EMAIL"]);
// Создаем переменные для массивов с файлами
$arFiles = [];
$arSingleFile = [];
// Обрабатываем поле FILES с несколькими файлами
if(!empty($_FILES['FILES']['tmp_name']) {
foreach($_FILES['FILES']['tmp_name'] as $key => $tmpName) {
if(!empty($tmpName)) {
$arFiles[] = [
'fileData' => [
$_FILES['FILES']['name'][$key],
base64_encode(file_get_contents($tmpName))
]
];
}
}
}
// Обрабатываем поле FILE с одним файлом
if(!empty($_FILES['FILE']['tmp_name'])) {
$arSingleFile = [
'fileData' => [
$_FILES['FILE']['name'],
base64_encode(file_get_contents($_FILES['FILE']['tmp_name']))
]
];
}
// Форматируем телефон и почту для Битрикс24 в формат crm_multifield
$arPhone = (!empty($sPhone)) ? array(array('VALUE' => $sPhone, 'VALUE_TYPE' => 'WORK')) : array();
$arEmail = (!empty($sEmail)) ? array(array('VALUE' => $sEmail, 'VALUE_TYPE' => 'HOME')) : array();
// Формируем заголовок лида из имени и фамилии
$sTitle = 'С сайта: ' . trim($sName . ' ' . $sLastName);
// Если есть название компании — добавляем его через тире после имени и фамилии
if (!empty($sCompanyTitle)) {
$sTitle .= ' — ' . $sCompanyTitle;
}
// Отправляем данные в Битрикс24
$result = CRest::call(
'crm.lead.add',
[
'fields' => [
'TITLE' => $sTitle, // Заголовок лида
'NAME' => $sName, // Имя
'LAST_NAME' => $sLastName, // Фамилия
'COMPANY_TITLE' => $sCompanyTitle, // Название компании
'PHONE' => $arPhone, // Телефон
'EMAIL' => $arEmail, // Email
'UF_CRM_LEAD_FILES' => $arFiles, // Поле для добавления нескольких файлов
'UF_CRM_LEAD_FILE' => $arSingleFile // Поле для файла
]
]
);
// Проверяем результат и выводим сообщение
if(!empty($result['result'])){
echo json_encode(['message' => 'Лид добавлен успешно']);
} elseif(!empty($result['error_description'])){
echo json_encode(['message' => 'Лид не добавлен: '.$result['error_description']]);
} else {
echo json_encode(['message' => 'Лид не добавлен']);
}
?>