Maison  >  Article  >  développement back-end  >  Comment obtenir les paramètres GET via PHP

Comment obtenir les paramètres GET via PHP

PHPz
PHPzoriginal
2023-03-31 09:10:445009parcourir

Dans le développement Web, PHP est un langage backend populaire. Lors de l'écriture d'applications en PHP, une question très courante est de savoir comment obtenir les paramètres d'une URL via une requête GET. Cet article explorera ce problème, expliquera comment obtenir les paramètres GET via PHP et présentera quelques conseils et considérations.

Tout d’abord, voyons comment obtenir les paramètres GET à l’aide de PHP. Obtenir les paramètres GET en utilisant PHP est très simple, utilisez simplement la variable $_GET. Lorsqu'une requête GET est lancée et que des paramètres sont soumis, ces paramètres seront ajoutés à la fin de l'URL sous la forme "?key=value". La variable $_GET contiendra des paires clé-valeur pour ces paramètres. Par exemple, si l'URL est "http://example.com?name=John&age=30", alors le tableau $_GET correspondant contiendra à la fois "name" => "John" et "age" => "30". -paires de valeurs.

L'exemple de code pour obtenir les paramètres GET à l'aide de PHP est le suivant :

<?php
if(isset($_GET[&#39;name&#39;])) { // 检查是否传入了name参数
 $name = $_GET[&#39;name&#39;]; // 获取name参数的值
 echo "Hello, $name!";
}
?>

Dans le code ci-dessus, nous vérifions d'abord si le paramètre "name" est transmis. Si tel est le cas, nous stockons sa valeur dans la variable $name et imprimons un message de bienvenue. Notez que nous utilisons des guillemets doubles pour encadrer la variable lors de la sortie de la chaîne. Cela permet à l'analyseur PHP d'intégrer la valeur de la variable dans la chaîne.

Cependant, utiliser simplement la variable $_GET pour obtenir les paramètres GET n'est pas suffisamment sûr. Les utilisateurs malveillants peuvent tenter d'attaquer des applications en créant manuellement des URL. Pour éviter cette attaque, il est recommandé de valider et filtrer les paramètres GET. Voici quelques techniques courantes de filtrage et de validation :

  1. Vérifiez que les paramètres existent

Attention à l'utilisation de variables non définies lors de la gestion des paramètres GET. Lorsque nous essayons d'obtenir des paramètres GET non définis, PHP génère un avertissement, exposant la vulnérabilité de l'application. Pour éviter cela, vous devez vérifier si le paramètre existe avant de continuer. Exemple de code :

<?php
if(isset($_GET[&#39;name&#39;])) {
 $name = $_GET[&#39;name&#39;]; // 如果参数存在,获取参数值
} else {
 $name = &#39;&#39;; // 如果参数不存在,设置默认值
}
?>
  1. Paramètres de filtrage et de nettoyage

Après avoir obtenu les paramètres GET, nous devons les filtrer et les nettoyer pour éviter les attaques malveillantes. Les balises HTML doivent être échappées à l'aide de htmlspecialchars() pour éviter les attaques de scripts intersites (XSS). Exemple de code :

<?php
if(isset($_GET[&#39;username&#39;])) {
 $username = htmlspecialchars($_GET[&#39;username&#39;]); // 获取参数并转义HTML标签
} else {
 $username = &#39;&#39;;
}
?>
  1. Vérifiez le type et la plage des valeurs des paramètres

Afin de garantir l'exactitude des paramètres, nous devons vérifier le type et la plage des valeurs des paramètres. Par exemple, nous pouvons utiliser la fonction is_numeric() pour vérifier si l'argument est un nombre valide. Exemple de code :

<?php
if(isset($_GET[&#39;age&#39;])) {
 if(is_numeric($_GET[&#39;age&#39;]) && $_GET[&#39;age&#39;] >= 1 && $_GET['age'] <= 100) {
   $age = $_GET[&#39;age&#39;];
 } else {
   $age = 0;
 }
} else {
 $age = 0;
}
?>

Dans le code ci-dessus, nous utilisons la fonction is_numeric() pour vérifier si le paramètre "age" est un nombre valide et utilisons une instruction conditionnelle pour vérifier si le paramètre "age" est compris entre 1 et 100. Si l'argument n'est pas un nombre valide ou si la plage est incorrecte, nous définirons une valeur par défaut.

Résumé :

Obtenir des paramètres à partir d'une URL via une requête GET est une exigence courante dans les applications Web. Obtenir les paramètres GET en utilisant PHP est très simple, utilisez simplement la variable $_GET. Cependant, pour éviter les attaques malveillantes, nous devons valider et filtrer les paramètres GET. Lors de la validation des paramètres, vous devez vérifier si les paramètres existent et échapper aux balises HTML à l'aide de la fonction htmlspecialchars(). Lors du filtrage des paramètres, le type et la portée des paramètres doivent être vérifiés pour garantir que les valeurs des paramètres saisies sont valides. Grâce à ces conseils, vous pouvez améliorer la sécurité des applications Web et protéger la confidentialité des utilisateurs et la sécurité 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!

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