http://

https://

http:// -- https:// — Accùs aux URLs HTTP(s)

Description

Permet des accĂšs, en lecture seule, Ă  des fichiers accessibles via HTTP. Par dĂ©faut, une requĂȘte HTTP 1.0 GET est utilisĂ©e. Un en-tĂȘte Host: est envoyĂ© avec la requĂȘte, pour gĂ©rer les hĂŽtes virtuels basĂ©s sur des noms. Si une version de navigateur a Ă©tĂ© configurĂ©e avec l'option user_agent dans le fichier php.ini ou via le contexte de flux, elle sera aussi incluse dans la requĂȘte.

Le flux permet d'accĂ©der au corps (body) de la ressource. Les en-tĂȘtes sont stockĂ©s dans la variable $http_response_header.

Pour connaĂźtre l'URL de la ressource depuis laquelle le document provient (aprĂšs l'exĂ©cution de toutes les redirections), il est nĂ©cessaire d'analyser la sĂ©rie d'en-tĂȘtes retournĂ©s par le flux.

La directive from sera utilisĂ©e pour l'en-tĂȘte From: si elle a Ă©tĂ© dĂ©finie, et non Ă©crasĂ©e par les Options et paramĂštres de contexte.

Utilisation

  • http://example.com
  • http://example.com/fichier.php?var1=val1&var2=val2
  • http://user:password@example.com
  • https://example.com
  • https://example.com/fichier.php?var1=val1&var2=val2
  • https://user:password@example.com

Options

Résumé de l'enveloppe
Attribut Supporté
Restreint par allow_url_fopen Oui
Autorise la lecture Oui
Autorise l'écriture Non
Autorise l'ajout Non
Autorise la lecture et l'écriture simultanément N/A
Support de la fonction stat() Non
Support de la fonction unlink() Non
Support de la fonction rename() Non
Support de la fonction mkdir() Non
Support de la fonction rmdir() Non

Exemples

Exemple #1 Détecte la derniÚre URL aprÚs des redirections

<?php
$url
= 'http://www.example.com/redirecting_page.php';

$fp = fopen($url, 'r');

$meta_data = stream_get_meta_data($fp);
foreach (
$meta_data['wrapper_data'] as $response) {

/* Avons-nous été redirigés ? */
if (strtolower(substr($response, 0, 10)) == 'location: ') {

/* mise Ă  jour de $url avec le chemin aprĂšs redirection */
$url = substr($response, 10);
}

}

?>

Notes

Note: HTTPS n'est supporté que si l'extension openssl est active.

Les connexions HTTP sont en lecture seule ; l'écriture de données ou la copie de fichier vers une ressource HTTP ne sont pas supportées.

L'envoi de requĂȘtes POST et PUT, par exemple, peut ĂȘtre effectuĂ© Ă  l'aide des contextes HTTP.

Voir aussi

add a note

User Contributed Notes 3 notes

up
7
dwalton at acm dot org ¶
19 years ago
As it says on this page:

"The stream allows access to the body of the resource; the headers are stored in the $http_response_header variable. Since PHP 4.3.0, the headers are available using stream_get_meta_data()."

This one sentence is the only documentation I have found on the mysterious $http_response_header variable, and I'm afraid it's misleading.  It implies that from 4.3.0 onward, stream_get_meta_data() ought to be used in favor of $http_response_header.  

Don't be fooled!  stream_get_meta_data() requires a stream reference, which makes it ONLY useful with fopen() and related functions.  However, $http_response_header can be used to get the headers from the much simpler file_get_contents() and related functions, which makes it still very useful in 5.x.

Also note that even when file_get_contents() and friends fail due to a 4xx or 5xx error and return false, the headers are still available in $http_response_header.
up
5
Rainer Perske ¶
10 years ago
Passing authentication information in the URL as in "https://user:password@example.com" works for HTTP "Basic" access authentication but not for HTTP "Digest" access authentication. You can use the cURL functions for servers requesting HTTP "Digest" access authentication.
up
1
NEA at AraTaraBul dot com ¶
18 years ago
HTTP post function;

<?php
function post_it($datastream, $url) { 

$url = preg_replace("@^http://@i", "", $url);
$host = substr($url, 0, strpos($url, "/"));
$uri = strstr($url, "/"); 

      $reqbody = "";
      foreach($datastream as $key=>$val) {
          if (!empty($reqbody)) $reqbody.= "&";
      $reqbody.= $key."=".urlencode($val);
      } 

$contentlength = strlen($reqbody);
     $reqheader =  "POST $uri HTTP/1.1\r\n".
                   "Host: $host\n". "User-Agent: PostIt\r\n".
     "Content-Type: application/x-www-form-urlencoded\r\n".
     "Content-Length: $contentlength\r\n\r\n".
     "$reqbody\r\n"; 

$socket = fsockopen($host, 80, $errno, $errstr);

if (!$socket) {
   $result["errno"] = $errno;
   $result["errstr"] = $errstr;
   return $result;
}

fputs($socket, $reqheader);

while (!feof($socket)) {
   $result[] = fgets($socket, 4096);
}

fclose($socket);

return $result;
}
?>