array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'pt_BR', ), 'this' => array ( 0 => 'context.http.php', 1 => 'Opções de contexto do HTTP', ), 'up' => array ( 0 => 'context.php', 1 => 'Opções e parâmetros de contexto', ), 'prev' => array ( 0 => 'context.socket.php', 1 => 'Opções de contexto de Socket', ), 'next' => array ( 0 => 'context.ftp.php', 1 => 'Opções de contexto do FTP', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'pt_BR', 'path' => 'language/context/http.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
Opções de contexto do HTTP — Lista de opções de contexto do HTTP
Opções de contexto dos transportadores http://
e
https://
.
Exemplo #1 Buscando uma página e enviando dados pelo método POST
<?php
$postdata = http_build_query(
array(
'var1' => 'some content',
'var2' => 'doh'
)
);
$opts = array('http' =>
array(
'method' => 'POST',
'header' => 'Content-type: application/x-www-form-urlencoded',
'content' => $postdata
)
);
$context = stream_context_create($opts);
$result = file_get_contents('http://example.com/submit.php', false, $context);
?>
Exemplo #2 Ignorando redirecionamentos, mas trazendo os cabeçalhos e conteúdo
<?php
$url = "http://www.example.org/header.php";
$opts = array('http' =>
array(
'method' => 'GET',
'max_redirects' => '0',
'ignore_errors' => '1'
)
);
$context = stream_context_create($opts);
$stream = fopen($url, 'r', false, $context);
// header information as well as meta data
// about the stream
var_dump(stream_get_meta_data($stream));
// actual data at $url
var_dump(stream_get_contents($stream));
fclose($stream);
?>
Nota: Opções de contextos de streams socket básicos
Opções de contextos adicionais podem ser suportadas em transportes básicos Em streamshttp://
, use as opções de contexto do transportetcp://
. Em streamshttps://
, use as opções de contexto do transportessl://
.
Nota: Linha de status HTTP
Quando este empacotador de stream faz um redirecionamento, owrapper_data
retornado pela função stream_get_meta_data() pode não conter necessariamente a linha de status HTTP, que atualmente se aplica ao conteúdo no índice0
.A primeira requisição retornouarray ( 'wrapper_data' => array ( 0 => 'HTTP/1.0 301 Moved Permanently', 1 => 'Cache-Control: no-cache', 2 => 'Connection: close', 3 => 'Location: http://example.com/foo.jpg', 4 => 'HTTP/1.1 200 OK', ...301
(redirecionamento permanente), então o empacotador de stream automaticamente fará o redirecionamento para conseguir uma resposta200
(índice =4
).