Maison développement back-end tutoriel php register_globals使用上的一些补充说明_PHP教程

register_globals使用上的一些补充说明_PHP教程

Jul 13, 2016 am 10:34 AM
安全性

register_globals是php.ini里的一个配置,这个配置影响到php如何接收传递过来的参数,如果你的问题是:为什么我的表单无法传递数据?为什么我的程序无法得到传递过来的变量?等等,那么你需要仔细的阅读以下的内容。 

register_globals的值可以设置为:On或者Off,我们举一段代码来分别描述它们的不同。 

<form name="frmTest" id="frmTest" action="URL"> 
	<input type="text" name="user_name" id="user_name"> 
	<input type="password" name="user_pass" id="user_pass"> 
	<input type="submit" value="login"> 
</form> 
Copier après la connexion

当register_globals=Off的时候,下一个程序接收的时候应该用$_GET['user_name']和$_GET['user_pass']来接受传递过来的值。(注:当

的method属性为post的时候应该用$_POST['user_name']和$_POST['user_pass'])

当register_globals=On的时候,下一个程序可以直接使用$user_name和$user_pass来接受值。

顾名思义,register_globals的意思就是注册为全局变量,所以当On的时候,传递过来的值会被直接的注册为全局变量直接使用,而Off的时候,我们需要到特定的数组里去得到它。所以,碰到上边那些无法得到值的问题的朋友应该首先检查一下你的register_globals的设置和你获取值的方法是否匹配。(查看可以用phpinfo()函数或者直接查看php.ini)

那我们为什么要使用Off呢?

php以后的新版本默认都用Off,虽然你可以设置它为On,但是当你无法控制服务器的时候,你的代码的兼容性就成为一个大问题,所以,你最好从现在就开始用Off的风格开始编程。

现在还有一个问题就是,以前用On风格写的大量脚本怎么办?

如果你以前的脚本规划得好,有个公共包含文件,比如config.inc.php一类的文件,在这个文件里加上以下的代码来模拟一下(这个代码不保证100%可以解决你的问题,因为我没有大量测试,但是我觉得效果不错)。另外,这个帖子里的解决方法也可以参考一下:

<?php 
if ( !ini_get('register_globals') ) 
{ 
    extract($_POST); 
    extract($_GET); 
    extract($_SERVER); 
    extract($_FILES); 
    extract($_ENV); 
    extract($_COOKIE); 
    
    if ( isset($_SESSION) ) 
    { 
        extract($_SESSION); 
    } 
} 
?> 
Copier après la connexion

register_globals = Off的情况不仅仅影响到如何获取从

、url传递过来的数据,也影响到session、cookie,对应的,得到session、cookie的方式应该为:$_SESSION[]、$_COOKIE。同时对于session的处理也有一些改变,比如,session_register()没有必要而且失效,具体的变化,请查看php manual里的Session handling functions

php manual 写到:

Variables provided to the script via the GET, POST, and COOKIE input mechanisms, and which therefore cannot be trusted. The presence and order of variable inclusion in this array is defined according to the PHP variables_order configuration directive.

$_REQUEST中间的内容实际上还是来源于$_GET $_POST $_COOKIE,缺点是无法判断变量到底来自于get post 还是cookie,对要求比较严格的场合不适用。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/752365.htmlTechArticleregister_globals是php.ini里的一个配置,这个配置影响到php如何接收传递过来的参数,如果你的问题是:为什么我的表单无法传递数据?为什么...
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Performances et sécurité de PHP5 et PHP8 : comparaison et améliorations Performances et sécurité de PHP5 et PHP8 : comparaison et améliorations Jan 26, 2024 am 10:19 AM

PHP est un langage de script côté serveur largement utilisé pour développer des applications Web. Il s'est développé en plusieurs versions, et cet article discutera principalement de la comparaison entre PHP5 et PHP8, avec un accent particulier sur ses améliorations en termes de performances et de sécurité. Jetons d’abord un coup d’œil à quelques fonctionnalités de PHP5. PHP5 est sorti en 2004 et a introduit de nombreuses nouvelles fonctions et fonctionnalités, telles que la programmation orientée objet (POO), la gestion des exceptions, les espaces de noms, etc. Ces fonctionnalités rendent PHP5 plus puissant et flexible, permettant aux développeurs de

Défis de sécurité dans le développement de Golang : Comment éviter d'être exploité pour la création de virus ? Défis de sécurité dans le développement de Golang : Comment éviter d'être exploité pour la création de virus ? Mar 19, 2024 pm 12:39 PM

Défis de sécurité dans le développement de Golang : Comment éviter d'être exploité pour la création de virus ? Avec la large application de Golang dans le domaine de la programmation, de plus en plus de développeurs choisissent d'utiliser Golang pour développer différents types d'applications. Cependant, comme pour d’autres langages de programmation, le développement de Golang présente des problèmes de sécurité. En particulier, la puissance et la flexibilité de Golang en font également un outil potentiel de création de virus. Cet article abordera les problèmes de sécurité dans le développement de Golang et fournira quelques méthodes pour éviter G.

Comment gérer les requêtes inter-domaines et les problèmes de sécurité dans le développement C# Comment gérer les requêtes inter-domaines et les problèmes de sécurité dans le développement C# Oct 08, 2023 pm 09:21 PM

Comment gérer les requêtes inter-domaines et les problèmes de sécurité dans le développement C#. Dans le développement d'applications réseau modernes, les requêtes inter-domaines et les problèmes de sécurité sont souvent des défis auxquels les développeurs sont souvent confrontés. Afin d'offrir une meilleure expérience utilisateur et de meilleures fonctionnalités, les applications doivent souvent interagir avec d'autres domaines ou serveurs. Cependant, la politique de même origine du navigateur entraîne le blocage de ces requêtes inter-domaines. Certaines mesures doivent donc être prises pour gérer les requêtes inter-domaines. Dans le même temps, afin de garantir la sécurité des données, les développeurs doivent également prendre en compte certains problèmes de sécurité. Cet article explique comment gérer les requêtes inter-domaines dans le développement C#.

Quelle est la relation entre les techniques de gestion de la mémoire et la sécurité dans les fonctions Java ? Quelle est la relation entre les techniques de gestion de la mémoire et la sécurité dans les fonctions Java ? May 02, 2024 pm 01:06 PM

La gestion de la mémoire en Java implique une gestion automatique de la mémoire, utilisant le garbage collection et le comptage de références pour allouer, utiliser et récupérer la mémoire. Une gestion efficace de la mémoire est cruciale pour la sécurité car elle évite les débordements de tampon, les pointeurs sauvages et les fuites de mémoire, améliorant ainsi la sécurité de votre programme. Par exemple, en libérant correctement les objets qui ne sont plus nécessaires, vous pouvez éviter les fuites de mémoire, améliorant ainsi les performances du programme et évitant les plantages.

Win11 doit-il installer un logiciel antivirus ? Win11 doit-il installer un logiciel antivirus ? Dec 27, 2023 am 09:42 AM

Win11 est livré avec un logiciel antivirus. De manière générale, l'effet antivirus est très bon et n'a pas besoin d'être installé. Cependant, le seul inconvénient est que vous verrez que le virus est d'abord désinstallé au lieu de vous le rappeler à l'avance. vous en avez besoin. Si vous l'acceptez, vous n'avez pas besoin de le télécharger. Win11 doit-il installer un logiciel antivirus ? Réponse : Non. De manière générale, Win11 est livré avec un logiciel antivirus et ne nécessite aucune installation supplémentaire. Si vous n'aimez pas la façon dont le logiciel antivirus fourni avec le système win11 est géré, vous pouvez le réinstaller. Comment désactiver le logiciel antivirus fourni avec Win11 : 1. Tout d'abord, nous entrons dans les paramètres et cliquons sur "Confidentialité et sécurité". 2. Cliquez ensuite sur « Centre de sécurité Windows ». 3. Sélectionnez ensuite « Protection contre les virus et les menaces ». 4. Enfin, vous pouvez le désactiver

Implémentation de la sécurité et de la transmission cryptée du protocole WebSocket Implémentation de la sécurité et de la transmission cryptée du protocole WebSocket Oct 15, 2023 am 09:16 AM

Sécurité et transmission cryptée Implémentation du protocole WebSocket Avec le développement d'Internet, les protocoles de communication réseau ont progressivement évolué. Le protocole HTTP traditionnel ne peut parfois pas répondre aux besoins de communication en temps réel. En tant que protocole de communication émergent, le protocole WebSocket présente les avantages d'excellentes performances en temps réel, d'une communication bidirectionnelle et d'une faible latence. Il est largement utilisé dans des domaines tels que le chat en ligne, le push en temps réel et les jeux. Cependant, en raison des caractéristiques du protocole WebSocket, certains problèmes de sécurité peuvent survenir lors du processus de communication. Ainsi, pour WebSo

Garanties de sécurité des itérateurs pour les bibliothèques de conteneurs C++ Garanties de sécurité des itérateurs pour les bibliothèques de conteneurs C++ Jun 05, 2024 pm 04:07 PM

La bibliothèque de conteneurs C++ fournit les mécanismes suivants pour assurer la sécurité des itérateurs : 1. Garantie d'immuabilité du conteneur ; 2. Itérateur de copie ; 3. Plage pour la boucle ; 4. Itérateur de const ;

Panne et sécurité du serveur Linux : comment gérer votre système sainement Panne et sécurité du serveur Linux : comment gérer votre système sainement Sep 10, 2023 pm 04:02 PM

Avec le développement de la technologie Internet, de plus en plus d'entreprises et de particuliers choisissent d'utiliser des serveurs Linux pour héberger et gérer leurs applications et sites Web. Cependant, à mesure que le nombre de serveurs augmente, les pannes de serveur et les problèmes de sécurité deviennent une tâche urgente. Cet article explorera les causes des pannes du serveur Linux et comment gérer et protéger le système de manière saine. Tout d'abord, examinons quelques raisons courantes pouvant entraîner un dysfonctionnement des serveurs Linux. Premièrement, la panne matérielle est l’une des raisons les plus courantes. Par exemple, le serveur surchauffe,

See all articles