Я бы порекомендовал использовать потоковые контексты PHP со встроенными функциями: http://us3.php.net/manual/en/book.stream.php.Полная функциональность HTTP / S и прекрасно интегрируется с функциями fopen
/ file_get_contents
.Вы можете (например) сделать POST следующим образом:
$chunk = file_get_contents("https://graph.facebook.com/oauth/access_token?client_id=".FACEBOOK_APP_ID."&client_secret=".FACEBOOK_SECRET."&grant_type=client_credentials");
if ($request_ids && $chunk) {
$cookie = explode('=', $chunk);
if (count($cookie) == 2) $cookie = $cookie[1];
else $cookie = $cookie[0];
// flush it
foreach ($request_ids as $request_id) {
$context = stream_context_create(array(
'http' => array(
'method' => 'POST',
'content' => 'method=DELETE',
'user_agent' => "Mozilla/5.0 (Windows; U; Windows NT 6.0; en-US; rv:1.9.0.6) Gecko/2009011913 Firefox/3.0.6 (.NET CLR 3.5.30729)",
'max_redirects' => 0
)
));
@file_get_contents('https://graph.facebook.com/' . $request_id . '?access_token=' . $cookie, false, $context);
}
}
Этот код входит в Facebook, извлекает токен для входа в приложение и затем использует безопасный HTTP POST для удаления ряда объектов с помощью API-интерфейса Graph.
Если вам нужно сделать что-то более необычное, вы тоже можете.
$context = stream_context_create(array('http' => array(
// set HTTP method
'method' => 'GET',
'user_agent' => "Mozilla/5.0 (Windows; U; Windows NT 6.0; en-US; rv:1.9.0.6) Gecko/2009011913 Firefox/3.0.6 (.NET CLR 3.5.30729)",
'max_redirects' => 0
)));
// extract the cookies
$fp = fopen(URL, "r", false, $context);
$meta = stream_get_meta_data($fp);
$headers = $metadata['wrapper_data'];
fclose($fp);
Будет регистрировать в журнале. Получит заголовки, возвращенные URL-адресом.Внешние библиотеки не требуются.