Maison >développement back-end >tutoriel php >Quelle est la différence entre les méthodes GET et POST

Quelle est la différence entre les méthodes GET et POST

青灯夜游
青灯夜游original
2018-12-07 17:05:41101731parcourir

Quelle est la différence entre les méthodes GET et POST ? Cet article vous donnera une introduction détaillée aux méthodes GET et POST afin que vous puissiez comprendre la différence entre les méthodes GET et POST. J'espère qu'il vous sera utile.

Quelle est la différence entre les méthodes GET et POST

Les navigateurs Web utilisent généralement l'une des deux méthodes HTTP (Hypertext Transfer Protocol) (méthode GET et méthode POST) pour communiquer avec le serveur. Ces deux méthodes transmettent les informations de différentes manières pour envoyer les données au serveur. Examinons de plus près les méthodes GET et POST.

Méthode GET

Dans la méthode GET, les données seront envoyées en tant que paramètres de l'URL, qui sont généralement des noms et une chaîne de paires de valeurs. Généralement, une URL avec des données GET ressemblera à ceci :

http://www.php.cn/action.php?name = john&age = 24

Dans le nom et l'âge de l'URL se trouvent tous deux des paramètres GET, john et 24 sont les valeurs de ces paramètres multiples " ; = valeur " peut être intégré dans une URL en la concaténant avec l'esperluette. On ne peut envoyer que des données texte simples via la méthode GET.

Avantages et inconvénients de l'utilisation de la méthode GET

1 Étant donné que les données envoyées par la méthode GET sont affichées dans l'URL, vous pouvez ajouter la page à vos favoris en utilisant un spécifique. valeur de la chaîne de requête.

2. La méthode GET n'est pas adaptée pour transmettre des informations sensibles telles que le nom d'utilisateur et le mot de passe, car ces informations sont entièrement visibles dans la chaîne de requête URL et peuvent être stockées dans la mémoire du navigateur client en tant que page consultée. .

3. Étant donné que la méthode GET attribue des données aux variables d'environnement du serveur, la longueur de l'URL est limitée. Il existe donc une limite au nombre total de données à envoyer.

PHP fournit la super variable globale $_GET pour accéder à toutes les informations envoyées via l'URL ; ou utilisez HTML pour envoyer des informations via les informations soumises via le formulaire HTML method="get".

Méthode POST

Dans la méthode POST, les données sont envoyées au serveur sous forme de paquet dans une communication séparée avec le script de traitement envoyé via ; Méthode POST Les données ne sont pas visibles dans l'URL.

La méthode POST convient aux situations où une grande quantité d'informations peut être transférée. Lorsque le serveur reçoit une demande via un formulaire utilisant POST, il transmet toutes les informations pertinentes saisies dans le formulaire immédiatement après avoir effectué la demande à l'URL.

Avantages et inconvénients de l'utilisation de la méthode POST

1 Elle est plus sécurisée que GET car les informations saisies par l'utilisateur ne sont jamais visibles dans la chaîne de requête URL ou. journaux du serveur.

2. Il existe une limite plus grande sur la quantité de données pouvant être transférées, on peut utiliser POST pour envoyer des données texte et des données binaires (télécharger des fichiers).

3. Les données envoyées par la méthode POST ne étant pas visibles dans l'URL, il n'est pas possible de mettre la page en signet à l'aide d'une requête spécifique.

PHP fournira une autre variable super globale $_POST pour accéder à toutes les informations envoyées via la méthode post ; ou utilisera method="post" pour envoyer des informations via des formulaires HTML.

La différence entre les méthodes GET et POST

Quelle est la différence entre les méthodes GET et POST

Bien que les méthodes GET et POST envoient des données Go au serveur et communiquer avec le serveur ; mais ces deux méthodes sont différentes. Jetons un coup d'œil à la différence entre les méthodes GET et POST.

1. Quantité de données envoyées

Dans Get, seule une quantité limitée de données peut être envoyée car les données sont envoyées dans l'URL

En POST, de grandes quantités de données peuvent être envoyées car les données sont envoyées dans le corps du texte.

2. Sécurité

Les données envoyées par la méthode GET ne sont pas protégées car les données sont exposées dans la barre d'URL, ce qui augmente le risque de vulnérabilités et d'attaques de pirates. .

Les données envoyées par la méthode POST sont sûres car les données ne sont pas exposées dans la barre d'URL et plusieurs techniques d'encodage peuvent y être utilisées, ce qui les rend résilientes.

3. Ajouter aux favoris

Les résultats de la requête GET peuvent être ajoutés aux favoris car ils existent sous forme d'URL alors que les résultats de la requête POST ne peuvent pas l'être ; ajouté aux favoris.

4. Encodage

Lors de l'utilisation de la méthode GET dans le formulaire, seuls les caractères ASCII sont acceptés dans le type de données.

Lors de la soumission du formulaire, la méthode POST ne lie pas le type de données du formulaire et autorise les caractères binaires et ASCII.

5. Taille de la variable

La taille de la variable dans la méthode GET est d'environ 2000 caractères. Cependant, la méthode POST autorise une taille variable allant jusqu'à 8 Mo.

6. Mise en cache

Les données de la méthode GET peuvent être mises en cache, mais les données de la méthode POST ne peuvent pas être mises en cache.

7. Fonctions principales

La méthode GET est principalement utilisée pour obtenir des informations. Cependant, la méthode POST est principalement utilisée pour mettre à jour les données.

Résumé : Ce qui précède représente l'intégralité du contenu de cet article, j'espère qu'il sera utile à l'étude de chacun.

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!

Déclaration:
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