Home  >  Article  >  Backend Development  >  Usage of PHP header() function (301, 404 and other error settings)

Usage of PHP header() function (301, 404 and other error settings)

WBOY
WBOYOriginal
2016-07-25 08:57:381204browse
  1. Header("HTTP/1.1 404 Not Found");
Copy code

For the ErrorDocument 404 /404.php function in the apache configuration, change the ErrorDocument 404 /404.php function in the nginx configuration

  1. error_page 404 /404.php;
Copy the code

and change it to

  1. error_page 404 = /404.php;
Copy code

php header 301

  1. header("HTTP/1.1 301 Moved Permanently");
  2. header ("Location:$url");
  3. ?>
Copy the code

No matter how many pages there are header, it will execute the last one, but conditionally, for example:

  1. header('Location:http://bbs.it-home.org');
  2. header('Location:http://www.g.cn');
  3. header('Location:http ://www.baidu.com');
Copy the code

This will jump to Baidu

  1. header('Location:http://bbs.it-home.org');echo 'Programmer's Home;
  2. header('Location:http://www.g.cn');
  3. header('Location:http://www.baidu.com');
Copy the code

This will jump to google Detailed instructions for using the header function 1. Function: PHP only sends the header of the HTML document to the browser using the HTTP protocol and tells the browser how to process the page. As for the transmitted content, you need to be familiar with the HTTP protocol and has nothing to do with PHP. Traditional headers must contain one of the following three headers and can only appear once.

  1. <1> Redirect function, this is the most common
  2. Header("Location: http://bbs.it-home.org/");
  3. ?>
Copy code

Forces users to get the latest information every time they visit this page, instead of using the client-side cache.

  1. //Tell the browser the expiration time of this page (expressed in Greenwich Mean Time), as long as it is a date that has passed.
  2. header("Expires: Mon, 26 Jul 1970 05:00:00 GMT");
  3. //Tell the browser the last updated date of this page (expressed in Greenwich Mean Time), which is the same day, the purpose is to force the browser to obtain Latest information
  4. header("Last-Modified: " . gmdate("D, d M Y H:i:s") . "GMT");
  5. //Tell the client browser not to use cache
  6. header("Cache-Control: no-cache, must-revalidate");
  7. //Parameters (compatible with previous servers), that is, compatible with HTTP1.0 protocol
  8. header("Pragma: no-cache");
  9. //Output MIME type
  10. header(" Content-type: application/file");
  11. //File length
  12. header("Content-Length: 227685");
  13. //Accepted range units
  14. header("Accept-Ranges: bytes");
  15. //Missing Time-saving file name in the file saving dialog box
  16. header("Content-Disposition: attachment; filename=$filename");
  17. ?>
Copy code

Output status value to the browser, mainly used Access control

  1. header('HTTP/1.1 401 Unauthorized');
  2. header('status: 401 Unauthorized');
  3. ?>
Copy code

For example, to restrict a user If you cannot access the page, you can set the status to 404, as shown below, so that the browser will display that the page does not exist.

  1. header('HTTP/1.1 404 Not Found');
  2. header("status: 404 Not Found");
  3. ?>
Copy code

Note: Traditional The header must contain one of the following three headers and can only appear once. Content-Type: xxxx/yyyy Location: xxxx:yyyy/zzzz Status: nnn xxxxxx can appear more than twice in the new multipart header specification (Multipart MIME).

Usage examples Example 1: This example redirects the browser to the official website of PHP.

  1. Header("Location: http://bbs.it-home.org/"); exit;
Copy code

Example 2: If you want users to get the latest data every time, instead of the data in the Proxy or cache, you can use the following headers

  1. header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
  2. header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); header("Cache-Control: no-cache, must-revalidate");
  3. header("Pragma: no-cache");
Copy code

Example 3: Let the user's browser A message that the file cannot be found appears.

  1. header("Status: 404 Not Found");
Copy code

Example 4: Let users download files.

  1. header("Content-type: application/x-gzip");
  2. header("Content-Disposition: attachment; filename=filename");
  3. header("Content-Description: PHP3 Generated Data" );
Copy code

header -- Send a raw HTTP header description void header ( string string [, bool replace [, int http_response_code]] )

The

header() function is used to send a raw HTTP header. See the HTTP/1.1 specification for more information on HTTP headers. The optional parameter replace specifies whether to replace the previous similar header or add a header of the same type. The default is replacement, but setting it to FALSE can force multiple headers of the same type to be sent. For example:

  1.  header('WWW-Authenticate: Negotiate');
  2. header('WWW-Authenticate: NTLM', false);
  3. ?>
Copy code

Second The optional parameter http_response_code forces the HTTP response code to the specified value (this parameter is new in PHP 4.3.0).

There are two special header calls. The first is a header that begins with the string "HTTP/" (case is not important), which can be used to determine the HTTP status code to be sent. For example, if you configure Apache to use PHP to handle error-handling requests for file not found (using the ErrorDocument directive), you need to ensure that the script generates the correct status code.

  1.  header("HTTP/1.0 404 Not Found")
  2. ?>
Copy code

Note: The HTTP status code header line is always the first one sent to client, regardless of whether the actual header() call is the first one. Unless HTTP headers have already been sent, they can be overwritten at any time by calling the header() function with a new status line.

HTTP status detection (HTTP Header):

The second special case is the "Location:" header. It doesn't just send this header back to the browser, it also returns a REDIRECT (302) status code to the browser, unless a 3xx status code has been issued previously.

  1.  header("Location: http://www.example.com/"); /* Redirect browser*/
  2.   /* Ensure that after redirection, subsequent code will not be Execute */
  3.  Exit;
  4. ?>
Copy code

Note: The HTTP/1.1 standard requires an absolute address URI as the Location: parameter, but some clients support relative URIs. You can usually use the $_SERVER['HTTP_HOST'], $_SERVER['PHP_SELF'] and dirname() functions to generate absolute URIs from relative URIs yourself:

  1.  header("Location: http://%22.$_server['http_host'/]
  2.  . rtrim(dirname($_SERVER['PHP_SELF']), '/\' )
  3.   ."/".$relative_url);
  4. ?>
Copy code

Note: Even if session.use_trans_sid is enabled, the Session ID will not be passed along with the Location header information. Must be passed manually as SID constant. ​ PHP scripts often produce dynamic content that must not be cached by browsers or proxy servers. Many proxy servers and browsers can disable caching by: Note: You may find that even without outputting all the code above, the web page is not buffered. There are many options that users can set to change the browser's default caching behavior. By sending the above headers, it should be possible to override any settings that could cause script pages to be cached. ​ Additionally, when sessions are used, the session_cache_limiter() function and the session.cache_limiter option can be used to automatically generate the correct cache-related headers. ​ Remember that header() must be called before any actual output, whether from regular HTML markup, blank lines or PHP. A common mistake is that when reading code through include(), require() or some other file access function, some spaces or empty lines are sent before calling header(). This error is also common in a single PHP/HTML file.

  1.  header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
  2. header("Expires: Mon, 26 Jul 1997 05:00:00 GMT "); // Past time
  3. ?>
Copy code

  1. /* This will generate an error because the output has been output before calling header()
  2.  * Got something*/
  3.  header('Location: http://www.example.com/');
  4. ?>
Copy code

Note: Since PHP 4, this can be solved by some output buffering functions this problem. The cost is that all output to the browser is cached on the server until a command is issued to send it. You can use ob_start() and ob_end_flush() in the code to achieve this function, or by modifying the output_buffering configuration option in php.ini, or by modifying the server configuration file.

Attached are two common uses of header():

  1. //Set page encoding:
  2. header('Content-Type: text/html;charset=gb2312');
  3. //Adjust page:
  4. header('location:http://www.baidu. com');
Copy code


Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn