HTTP bağlamı seçenekleri
  HTTP bağlamı seçenekleri — HTTP bağlamı seçeneklerinin listesi
  
 
  Açıklama
  
   http:// ve https:// aktarımları için
   bağlam seçenekleri.
  
  
 
  Seçenekler
  
   
    
     - 
      methodstring
- 
      
       Uzak sunucu tarafından desteklenen GET,POSTveya başka bir HTTP yöntemi.
 
       GETöntanımlıdır.
 
- 
      
       İstek sırasında gönderilecek ek başlıklar. Bu seçenekte belirtilen
       değerler, ardından gelen Location:yönlendirmelerinde bile, diğer değerleri geçersiz kılar
       (User-agent:,Host:,Authentication:gibi). Bu bakımdan,follow_locationetkinkenHost:başlığının atanması önerilmez.
 
- 
      user_agentstring
- 
      
       User-Agent:başlığı ile gönderilecek değer. Bu değer
       sadece, tarayıcıheaderseçeneği ile
       belirtilmemişse kullanılır.
 
       Öntanımlı olarak, php.ini dosyasındaki user_agent değeri kullanılır.
       
- 
      contentstring
- 
      
       Başlıklardan sonra gönderilecek ek veri. Normalde POST veya PUT
       istekleriyle kullanılır.
       
- 
      proxystring
- 
      
       Vekil sunucunun adresini belirten URI
       (tcp://vekil.example.com:5100gibi).
 
- 
      request_fulluribool
- 
      
       trueatanırsa, istek oluşturulurken URI'nin tamamı kullanılır
       (GET http://example.com/dizin/yolu/dosya.html
       HTTP/1.0gibi). Bu standart dışı bir istek biçimi olsa da
       bazı vekil sunucular bunun böyle olmasını gerektirirler.
 
       falseöntanımlıdır.
 
- 
      follow_locationint
- 
      
       Locationbaşlık yönlendirmelerini izler.
       İptal etmek için0atayın.
 
       1öntanımlıdır.
 
- 
      max_redirectsint
- 
      
       İzlenecek yönlendirmelerin azami sayısı. 1veya
       daha az bir değer belirtilmesi hiçbir yönlendirmenin izlenmeyeceği
       anlamına gelir.
 
       20öntanımlıdır.
 
- 
      protocol_versionfloat
- 
      
       HTTP protokolünün sürümü.
       
       PHP 8.0.0 itibariyle 1.1öntanımlıdır, evvelce1.0sürümü öntanımlıydı.
 
- 
      timeoutfloat
- 
      
       Bir float değer olarak saniye cinsinden okuma zaman aşımı.
       (10.5gibi).
 
       Öntanımlı olarak, php.ini dosyasındaki default_socket_timeout
       yönergesinin değeri kullanılır.
       
- 
      ignore_errorsbool
- 
      
       Başarısızlık durumu kodlarında bile içerik alınır.
       
       falseöntanımlıdır.
 
 
 
  Örnekler
  
   
    Örnek 1 - Bir sayfayı çekip veriyi POST ile göndermek
    
<?php
$postverisi = http_build_query(
    array(
        'var1' => 'biraz içerik',
        'var2' => 'eh işte'
    )
);
$seçenekler = array('http' =>
    array(
        'method'  => 'POST',
        'header'  => 'Content-type: application/x-www-form-urlencoded',
        'content' => $postverisi
    )
);
$bağlam = stream_context_create($seçenekler);
$sonuç = file_get_contents('http://example.com/submit.php', false, $bağlam);
?>
     
    
  
  
   
    Örnek 2 - Başlıklar ve içerik alınırken yönlendirmeleri yoksaymak 
    
<?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);
// meta veri ve başlıklar
var_dump(stream_get_meta_data($stream));
// esas veri
var_dump(stream_get_contents($stream));
fclose($stream);
?>
     
    
  
  
 
  Notlar
  Bilginize: 
   Temel soket akımı bağlamı seçenekleri
   
    Ek bağlamsal seçenekler temel
    aktarım tarafından desteklenebilir.  http://
    akımları için tcp:// aktarımının bağlamsal
    seçeneklerine atıf yapılır. https:// akımları için ise
    ssl:// aktarımının bağlamsal seçeneklerine atıf
    yapılır.
   
  
  Bilginize: 
   HTTP durum satırı
   
    Bu akım sarmalayıcı bir yönlendirmeyi izlerken
    stream_get_meta_data() tarafından döndürülen
    wrapper_data, gerçekte 0 indisinde
    içerik verisine uygulanan HTTP durum satırını içermeyebilir.
   
   
array (
  'wrapper_data' =>
  array (
    0 => 'HTTP/1.0 301 Moved Permantenly',
    1 => 'Cache-Control: no-cache',
    2 => 'Connection: close',
    3 => 'Location: http://example.com/foo.jpg',
    4 => 'HTTP/1.1 200 OK',
    ...
 
   
    İlk istek 301 (kalıcı yönlendirme) ile döndü, dolayısıyla
    akım sarmalayıcı otomatik olarak yönlendirmeyi izleyip bir
    200 yanıtı aldı (indis = 4).