Maison > développement back-end > tutoriel php > Pourquoi 'method=\'post\' enctype=\'text/plain\'' provoque-t-il une incompatibilité avec le tableau $_POST de PHP ?

Pourquoi 'method=\'post\' enctype=\'text/plain\'' provoque-t-il une incompatibilité avec le tableau $_POST de PHP ?

Linda Hamilton
Libérer: 2024-12-13 04:38:37
original
1017 Les gens l'ont consulté

Why does

Dévoiler les mystères : comprendre l'énigme de l'incompatibilité "method="post" enctype="text/plain"

Dans le domaine de développement Web, il arrive souvent que les données de formulaire transmises via les méthodes POST ne parviennent pas à atteindre leur destination prévue lorsque l'attribut enctype est défini sur "text/plain". En approfondissant les subtilités de ce problème, nous cherchons à démêler ses complexités et à découvrir la cause sous-jacente de cette incompatibilité.

Plonger dans les profondeurs : pourquoi PHP ne parvient pas à remplir $_POST

Le nœud du problème réside dans l'incapacité de PHP à gérer l'encodage "text/plain" malgré l'attribution d'une valeur à la variable. $HTTP_RAW_POST_DATA, PHP ne parvient pas à remplir le tableau $_POST avec les données du formulaire. Ce n'est pas un simple oubli mais une décision de conception intentionnelle.

Distinguer GET et POST : une histoire d'encodages

Il est crucial de différencier les méthodes GET et POST. Dans GET, les variables constituent la chaîne de requête au sein de l'URL, nécessitant un codage d'URL. Quel que soit l'attribut enctype, les navigateurs encodent automatiquement les variables GET en URL, ce qui rend le "text/plain" inefficace.

À l'inverse, avec POST, les variables ne font pas partie de l'URL mais sont transmises comme en-tête final de la requête HTTP. Ici, les options d'encodage "text/plain" et "application/x-www-form-urlencoded" sont disponibles, mais seule cette dernière fournit une solution non ambiguë.

L'ambiguïté se cache dans "text/ plain": Une mise en garde

Bien que "text/plain" semble être un encodage simple, il recèle un piège caché. Il manque de mécanismes pour délimiter plusieurs valeurs, ce qui peut conduire à des interprétations ambiguës des données d'entrée. Par exemple, en considérant le formulaire suivant :

<form method="post" enctype="text/plain" action="proc.php">
<textarea name="input1">abc
input2=def</textarea>
<input name="input2" value="ghi" />
<input type="submit">
</form>
Copier après la connexion

Si ce formulaire soumet des données à un script PHP en attendant des valeurs pour "input1" et "input2", une ambiguïté surgit :

print($HTTP_RAW_POST_DATA);
Copier après la connexion

En fonction sur l'interprétation, le résultat pourrait être :

  • input1=abcrninput2=def, input2=ghi
  • input1=abc, input2=defrninput2=ghi

Une telle ambiguïté est absente avec l'encodage "application/x-www-form-urlencoded", garantissant une récupération fiable des données.

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!

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal