Maison > développement back-end > tutoriel php > Explication détaillée des raisons pour lesquelles le saut de page d'emplacement d'en-tête échoue

Explication détaillée des raisons pour lesquelles le saut de page d'emplacement d'en-tête échoue

伊谢尔伦
Libérer: 2023-03-11 08:48:01
original
9218 Les gens l'ont consulté

Informations d'en-tête http
Les informations d'en-tête ont de nombreuses fonctions, les plus importantes sont les suivantes :
1.Sauter
Lorsque le navigateur accepte l'en-tête. Après Location: xxxx dans les informations, il passera automatiquement à l'adresse URL pointée par xxxx. C'est un peu similaire à l'écriture d'un saut avec js. Mais ce saut n'est connu que par le navigateur, et les utilisateurs ne peuvent pas le voir, qu'il y ait ou non quelque chose dans le contenu.
Exemple : header("Location: //m.sbmmt.com/");
2. Précisez le contenu de la page Web
Le même fichier XML, si les informations d'en-tête Si vous spécifiez : Content-type : application/xml, le navigateur l'analysera selon le format de fichier XML. Cependant, si les informations d'en-tête sont : Content-type : text/xml, le navigateur les analysera en tant que texte stocké. (Les navigateurs n'analysent pas les fichiers en fonction des extensions)
Exemple : header('Content-type: application/pdf');
Pièce jointe
Je ne sais pas si vous Je l'ai remarqué, parfois lors du téléchargement de quelque chose à partir de certains sites Web, après avoir cliqué sur le lien de téléchargement, le navigateur ouvre la pièce jointe en tant que page Web et tout le contenu affiché est des caractères tronqués. Ce problème est également lié aux informations d'en-tête. Parfois, le navigateur détermine s'il doit ouvrir ou enregistrer en fonction du type de contenu. Il arrive donc qu'il fasse un mauvais jugement (principalement parce que le concepteur du site Web oublie d'écrire le type de contenu). En fait, il existe une autre façon de spécifier que le contenu est une pièce jointe et doit être enregistré : Content-Disposition: filename="xxxxx"
Exemple : header('Content-Disposition: attachment; filename). ="downloaded.pdf "');
//Ouvrez le fichier et affichez
readfile('original.pdf');
Code d'état du protocole HTTP
1×× Réservé
2× × Indique que la demande a réussi Recevoir
3×× Le client doit affiner davantage la demande pour terminer la demande
4×× Erreur client
5×× Erreur serveur

Syntaxe :

header(string,replace,http_response_code)
Copier après la connexion

Paramètre
chaîne : obligatoire. Spécifie l'en-tête chaîne à envoyer.
remplacer : facultatif. Indique si cet en-tête remplace l'en-tête précédent ou ajoute un deuxième en-tête. La valeur par défaut est vraie (remplacement). false (autoriser plusieurs en-têtes du même type).
http_response_code : facultatif. Force le code de réponse HTTP à la valeur spécifiée. (Disponible en PHP 4 et supérieur)
Exemple 1 :
Redirection d'une page Web

   <?php 
      header("Location: //m.sbmmt.com/");
      exit;
   ?>
Copier après la connexion

Exemple 2 :
Forcer les utilisateurs à obtenir les dernières informations à chaque fois qu'ils visitent cette page page , au lieu d'utiliser le cache qui existe côté client.

   <?php  
       //告诉浏览器此页面的过期时间(用格林威治时间表示),只要是已经过去的日期即可。  
       header("Expires:Mon,26 Jul 1970 05:00:00 GMT");  
       //告诉浏览器此页面的最后更新日期(用格林威治时间表示)也就是当天,目的就是强迫浏览器获取最新资料  
       header("Last-Modified:".gmdate("D,d M Y H:i:s")."GMT");  
       //告诉客户端浏览器不使用缓存  
       header("Cache-Control:    no-cache,    must-revalidate");  
       //参数(与以前的服务器兼容),即兼容HTTP1.0协议  
       header("Pragma:    no-cache"); 
  ?>
Copier après la connexion

Exemple 3 :
Valeur d'état de sortie vers le navigateur, principalement utilisée pour le contrôle d'accès

   <?php  
       header(&#39;HTTP/1.1 401 Unauthorized&#39;);  
       header(&#39;status: 401 Unauthorized&#39;);  
   ?>
Copier après la connexion

Exemple 4 :
Pour restreindre l'accès d'un utilisateur à la page , vous pouvez définir le statut sur 404, comme indiqué ci-dessous, afin que le navigateur affiche que la page n'existe pas

   <?php  
       header(&#39;HTTP/1.1    404    Not Found&#39;);  
       header("status:    404    Not Found"); //这种写法错误
   ?>
Copier après la connexion

Exemple 5 :
L'emplacement du fichier caché
La balise html peut réaliser un téléchargement de fichiers ordinaire. Si vous souhaitez garder le fichier confidentiel et que vous ne pouvez pas communiquer le lien du fichier à d'autres personnes, vous pouvez utiliser la fonction d'en-tête pour télécharger le fichier.

header("Content-type: audio/mpeg");
header("Content-Disposition: attachment; filename=filenale");
header("Content-Description: PHP3 Generated Data");
Copier après la connexion

Exemple 6 :
Saisir le contenu avant la fonction d'en-tête
De manière générale, le contenu HTML ne peut pas être généré avant la fonction d'en-tête. De même, il existe des fonctions setcookie() et session. doit être Ajouter des informations d’en-tête de message au flux de sortie. S'il y a des instructions telles que echo avant l'exécution de header(), lorsque header() est rencontré plus tard, une erreur "Avertissement : Impossible de modifier les informations d'en-tête - en-têtes déjà envoyés par..." sera signalée. C'est-à-dire qu'il ne peut y avoir de texte, de lignes vides, de retours chariot, etc. devant ces fonctions, et il est préférable d'ajouter la fonction exit() après la fonction header(). Par exemple, dans l'écriture incorrecte suivante, il y a une ligne vide entre les deux sections code php  :

<?php
//some code here
?>
//这里应该是一个空行
<?php
    header("http/1.1 403 Forbidden");
    exit();
?>
Copier après la connexion

原因:
PHP脚本开始执行 时,它可以同时发送http消息头部(标题)信息和主体信息. http消息头部(来自 header() 或SetCookie() 函数)并不会立即发送,相反,它被保存到一个列表中. 这样就可以允许你修改标题信息,包括缺省的标题(例如Content-Type 标题).但是,一旦脚本发送了任何非标题的输出(例如,使用 HTML 或 print()调用),那么PHP就必须先发送完所有的Header,然后终止 HTTPheader.而后继续发送主体数据.从这时开始,任何添加或修改Header信息的试图都是不允许的,并会发送上述的错误消息之一。
解决办法:
修改php.ini打开缓存(output_buffering),将output_buffering=0修改成output_buffering=4096
或者在程序中使用缓存函数ob_start(),ob_end_flush() 等。原理是:output_buffering被启用时,在脚本发送输出时,PHP并不发送HTTPheader。相反,它将此输出通过管道(pipe)输入到动态增加的缓存中(只能在PHP4.0中使用,它具有中央化的输出机制)。你仍然可以修改/添加header,或者设置cookie,因为 header实际上并没有发送。当全部脚本终止时,PHP将自动发送HTTP header到浏览器,然后再发送输出缓冲中的内容。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal