https://
Allows read-only access to files/resources via HTTP. By default, a HTTP 1.0 GET is used. A Host: header is sent with the request to handle name-based virtual hosts. If you have configured a user_agent string using your php.ini file or the stream context, it will also be included in the request.
The stream allows access to the body of the resource; the headers are stored in the $http_response_header variable.
If it’s important to know the URL of the resource where your document came from (after all redirects have been processed), you’ll need to process the series of response headers returned by the stream.
The from directive will be used for the From: header if set and not overwritten by the Context options and parameters.
Usage
- http://example.com
- http://example.com/file.php?var1=val1&var2=val2
- http://user:password@example.com
- https://example.com
- https://example.com/file.php?var1=val1&var2=val2
- https://user:password@example.com
Options
Attribute | Supported |
---|---|
Restricted by allow_url_fopen | Yes |
Allows Reading | Yes |
Allows Writing | No |
Allows Appending | No |
Allows Simultaneous Reading and Writing | N/A |
Supports stat() | No |
Supports unlink() | No |
Supports rename() | No |
Supports mkdir() | No |
Supports rmdir() | No |
Examples
Example #1 Detecting which URL we ended up on after redirects
$meta_data = stream_get_meta_data ( $fp );
foreach ( $meta_data [ ‘wrapper_data’ ] as $response )
/* Were we redirected? */
if ( strtolower ( substr ( $response , 0 , 10 )) == ‘location: ‘ )
/* update $url with where we were redirected to */
$url = substr ( $response , 10 );
>
Notes
Note: HTTPS is only supported when the openssl extension is enabled.
HTTP connections are read-only; writing data or copying files to an HTTP resource is not supported.
Sending POST and PUT requests, for example, can be done with the help of HTTP Contexts.
See Also
User Contributed Notes 4 notes
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.
«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.
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 . » keyword»>. 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 ;
>
while (! feof ( $socket )) $result [] = fgets ( $socket , 4096 );
>
HTTP and HTTPS
Allows read-only access to files/resources via HTTP 1.0, using the HTTP GET method. A Host: header is sent with the request to handle name-based virtual hosts. If you have configured a user_agent string using your ini file or the stream context, it will also be included in the request.
When using SSL, Microsoft IIS will violate the protocol by closing the connection without sending a close_notify indicator. PHP will report this as «SSL: Fatal Protocol Error» when you reach the end of the data. To workaround this, you should lower your error_reporting level not to include warnings. PHP 4.3.7 and higher can detect buggy IIS server software when you open the stream using the https:// wrapper and will suppress the warning for you. If you are using fsockopen() to create an ssl:// socket, you are responsible for detecting and suppressing the warning yourself.
Redirects have been supported since PHP 4.0.5; if you are using an earlier version you will need to include trailing slashes in your URLs. If it’s important to know the URL of the resource where your document came from (after all redirects have been processed), you’ll need to process the series of response headers returned by the stream.
Example M-2. Fetch a page and send POST data
‘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); ?>
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() .
HTTP connections are read-only; you cannot write data or copy files to an HTTP resource.
Note: HTTPS is supported starting from PHP 4.3.0, if you have compiled in support for OpenSSL.
Attribute | Supported |
---|---|
Restricted by allow_url_fopen . | Yes |
Allows Reading | Yes |
Allows Writing | No |
Allows Appending | No |
Allows Simultaneous Reading and Writing | N/A |
Supports stat() | No |
Supports unlink() | No |
Supports rename() | No |
Supports mkdir() | No |
Supports rmdir() | No |
Name | Usage | Default |
---|---|---|
method | GET , POST , or any other HTTP method supported by the remote server. | GET |
header | Additional headers to be sent during request. Values in this option will override other values (such as User-agent: , Host: , and Authentication: ). | |
user_agent | Value to send with User-Agent: header. This value will only be used if user-agent is not specified in the header context option above. | php.ini setting: user_agent |
content | Additional data to be sent after the headers. Typically used with POST or PUT requests. | |
proxy | URI specifying address of proxy server. (e.g. tcp://proxy.example.com:5100 ). HTTPS proxying (through HTTP proxies) only works in PHP 5.1.0 or greater. | |
request_fulluri | When set to TRUE , the entire URI will be used when constructing the request. (i.e. GET http://www.example.com/path/to/file.html HTTP/1.0 ). While this is a non-standard request format, some proxy servers require it. | FALSE |
max_redirects | The max number of redirects to follow. Value 1 or less means that no redirects are followed. Added in PHP 5.1.0. | 20 |
Underlying socket stream context options: Additional context options may be supported by the underlying transport For http:// streams, refer to context options for the tcp:// transport. For https:// streams, refer to context options for the ssl:// transport.
Custom headers may be sent with an HTTP request prior to version 5 by taking advantage of a side-effect in the handling of the user_agent INI setting. Set user_agent to any valid string (such as the default PHP/version setting) followed by a carriage-return/line-feed pair and any additional headers. This method works in PHP4 and all later versions.
Example M-3. Sending custom headers with an HTTP request
Results in the following request being sent: