(PHP 5 >= 5.5.0, PHP 7)
curl_share_setopt — Установить опции разделяемого обработчика cURL
$sh
, int $option
, string $value
)Устанавливает опции разделяемого обработчика cURL.
sh
Обреботчик cURL полученый из curl_share_init()
option
Опция | Описание |
---|---|
CURLSHOPT_SHARE |
Задает тип данных, которые необходимо разделять. |
CURLSHOPT_UNSHARE |
Задает тип данных, которые больше не надо разделять. |
value
Значение | Описание |
---|---|
CURL_LOCK_DATA_COOKIE |
Куки. |
CURL_LOCK_DATA_DNS |
Кеш DNS. Обратите внимание, что если вы используете множественный обработчик cURL, то разделены будут кеши всех обработчиков в его составе. |
CURL_LOCK_DATA_SSL_SESSION |
Идентификаторы сессий SSL. Позволяет сократить время на установление сессии SSL при переконнекте к тому же самому серверу. Помните, что идентификатор сессии SSL будет по умолчанию переиспользоваться тем же самым обработчиком. |
Возвращает TRUE
в случае успешного завершения или FALSE
в случае возникновения ошибки.
Пример #1 curl_share_setopt() example
В этом примере мы создаем разделяемый обработчик cURL, добавляем в него два обычных обработчика и запускаем их. Они будут использовать одни и те же куки.
<?php
// Создаем разделяемый обработчик и настраиваем его на обмен куками
$sh = curl_share_init();
curl_share_setopt($sh, CURLSHOPT_SHARE, CURL_LOCK_DATA_COOKIE);
// Инициализируем первый обработчик cURL и связываем его с разделяемым
$ch1 = curl_init("http://example.com/");
curl_setopt($ch1, CURLOPT_SHARE, $sh);
// Запускаем первый запрос
curl_exec($ch1);
// Инициализируем второй обработчик cURL и связываем его с разделяемым
$ch2 = curl_init("http://php.net/");
curl_setopt($ch2, CURLOPT_SHARE, $sh);
// Запускаем второй обработчик.
// Ему будут доступны все куки от первого обработчика $ch1
curl_exec($ch2);
// Закрываем разделяемый обработчик
curl_share_close($sh);
// Закрываем оба обычных обработчика
curl_close($ch1);
curl_close($ch2);
?>