Maison développement back-end tutoriel php Analyse de l'utilisation de la méthode I de ThinkPHP

Analyse de l'utilisation de la méthode I de ThinkPHP

Jun 09, 2018 am 09:41 AM
thinkphp

La méthode I de ThinkPHP est un nouveau membre parmi de nombreuses fonctions à une seule lettre. Elle est principalement utilisée pour obtenir les variables d'entrée système de manière plus pratique et plus sûre, et peut être utilisée n'importe où. Cet article présente principalement la méthode I de ThinkPHP. Les amis qui en ont besoin peuvent s'y référer

La méthode I de ThinkPHP est un nouveau membre de nombreuses fonctions à une seule lettre. Son nom vient de l'anglais Input (input) et est. principalement utilisé pour Il est plus pratique et plus sûr d'obtenir des variables d'entrée système et peut être utilisé n'importe où. Le format d'utilisation est le suivant :
I('Type de variable. Nom de la variable',['Valeur par défaut'], ['Méthode de filtrage'])
Le type de variable fait référence à la méthode de requête ou au type d'entrée.

La signification de chaque type de variable est la suivante :

Type de variable Signification
obtenir Obtenir les paramètres GET
post Obtenir les paramètres POST
param Déterminer automatiquement le type de requête pour obtenir les paramètres GET, POST ou PUT
request Obtenir les paramètres REQUEST
put Obtenir les paramètres PUT
session Obtenir le paramètre $_SESSION
cookie Obtenir le paramètre $_COOKIE
serveur Obtenir le paramètre $_SERVER
globaux Obtenir les paramètres $GLOBALS


Remarque : les types de variables ne sont pas sensibles à la casse.
Les noms de variables sont strictement sensibles à la casse.
La valeur par défaut et la méthode de filtrage sont des paramètres facultatifs.

1. Utilisation :

Prenons le type de variable GET comme exemple pour illustrer l'utilisation de la méthode I :

echo I('get.id'); // 相当于 $_GET['id']
echo I('get.name'); // 相当于 $_GET['name']
Copier après la connexion

Valeur par défaut prise en charge :

echo I('get.id',0); // 如果不存在$_GET['id'] 则返回0
echo I('get.name',''); // 如果不存在$_GET['name'] 则返回空字符串
Copier après la connexion

Filtrer par méthode :

echo I('get.name','','htmlspecialchars'); // 采用htmlspecialchars方法对$_GET['name'] 进行过滤,如果不存在则返回空字符串
Copier après la connexion

prend en charge l'obtention directe du type de variable entier, par exemple :

I('get.'); // 获取整个$_GET 数组
Copier après la connexion

De la même manière, nous pouvons obtenir des variables de publication ou d'autres types d'entrée, par exemple :

I('post.name','','htmlspecialchars'); // 采用htmlspecialchars方法对$_POST['name'] 进行过滤,如果不存在则返回空字符串
I('session.user_id',0); // 获取$_SESSION['user_id'] 如果不存在则默认为0
I('cookie.'); // 获取整个 $_COOKIE 数组
I('server.REQUEST_METHOD'); // 获取 $_SERVER['REQUEST_METHOD']
Copier après la connexion

Le type de variable param est un cadre. Une méthode d'acquisition de variable unique qui prend en charge le jugement automatique du type de requête actuel, par exemple :

echo I('param.id');
Copier après la connexion

Si le type de requête actuel est GET, alors cela équivaut à $_GET['id'], si le type de requête actuel est POST ou PUT, alors cela équivaut à obtenir $_POST['id'] ou l'identifiant du paramètre PUT.
Et la variable de type param peut également utiliser un index numérique pour obtenir les paramètres d'URL (le paramètre du mode PATHINFO doit être valide, qu'il soit GET ou POST), par exemple :
L'adresse URL d'accès actuelle est
http : //serverName/index.php/New/2013/06/01

Ensuite, nous pouvons passer le

echo I('param.1'); // 输出2013
echo I('param.2'); // 输出06
echo I('param.3'); // 输出01
Copier après la connexion

fait Ci-dessus, la méthode d'écriture du type de variable param peut être simplifiée comme suit :

I('id'); // 等同于 I('param.id')
I('name'); // 等同于 I('param.name')
Copier après la connexion

2. Filtrage des variables

Lors de l'utilisation de la méthode I, les variables passent en fait par deux filtres. Le premier est le filtrage global. Le filtrage global se fait en configurant le paramètre VAR_FILTERS. Il faut noter ici qu'après la version 3.1, le mécanisme de filtrage de. le paramètre VAR_FILTERS a été modifié en filtrage récursif à l'aide de la méthode array_walk_recursive. Oui, la principale exigence pour la méthode de filtrage est qu'elle doit être renvoyée par référence, donc la définition de htmlspecialchars ici n'est pas valide. Vous pouvez personnaliser une méthode, par exemple : <🎜. >

function filter_default(&$value){
 $value = htmlspecialchars($value);
 }
Copier après la connexion

Puis configurez :


&#39;VAR_FILTERS&#39;=>&#39;filter_default&#39;
Copier après la connexion

Si vous devez filtrer plusieurs fois, vous pouvez utiliser :


&#39;VAR_FILTERS&#39;=>&#39;filter_default,filter_exp&#39;
Copier après la connexion

La méthode filter_exp est une méthode de filtrage de sécurité intégrée au framework, qui est utilisé pour empêcher les attaques par injection en utilisant la fonction EXP du modèle.

Parce que le paramètre VAR_FILTERS définit un mécanisme de filtrage global et utilise un filtrage récursif, ce qui a un impact sur l'efficacité, nous recommandons donc de filtrer directement les variables, sauf dans la troisième étape de la méthode I. méthode de filtrage de paramétrage, vous pouvez également définir le filtrage en configurant le paramètre DEFAULT_FILTER. En fait, le réglage par défaut de ce paramètre est :


&#39;DEFAULT_FILTER&#39;  => &#39;htmlspecialchars&#39;
Copier après la connexion

<🎜. >En d'autres termes, toutes les variables d'acquisition de la méthode I seront filtrées par htmlspecialchars, puis :


I(&#39;get.name&#39;); // 等同于 htmlspecialchars($_GET[&#39;name&#39;])
Copier après la connexion

De même, ce paramètre peut également prend en charge plusieurs filtres, par exemple :


&#39;DEFAULT_FILTER&#39;  => &#39;strip_tags,htmlspecialchars&#39;
Copier après la connexion

I(&#39;get.name&#39;); // 等同于 htmlspecialchars(strip_tags($_GET[&#39;name&#39;]))
Copier après la connexion

Si nous utilisons la méthode I Si la méthode de filtrage est précisée, le paramètre DEFAULT_FILTER sera ignoré, par exemple :


echo I(&#39;get.name&#39;,&#39;&#39;,&#39;strip_tags&#39;); // 等同于 strip_tags($_GET[&#39;name&#39;])
Copier après la connexion

Si le troisième paramètre de la La méthode I est passée Saisir le nom de la fonction signifie appeler la fonction pour filtrer la variable et la renvoyer (si la variable est un tableau, array_map est automatiquement utilisé pour le filtrage), sinon la méthode filter_var intégrée de PHP sera appelée pour le filtrage, par exemple :


I(&#39;post.email&#39;,&#39;&#39;,FILTER_VALIDATE_EMAIL);
Copier après la connexion

signifie que le format de $_POST['email'] sera vérifié, et s'il ne répond pas aux exigences, une chaîne vide sera renvoyée.

(Pour plus de formats de vérification, veuillez vous référer au manuel officiel d'utilisation de filter_var.)

Ou vous pouvez utiliser l'identification de caractère suivante :


I(&#39;post.email&#39;,&#39;&#39;,&#39;email&#39;);
Copier après la connexion

Les noms de filtres qui peuvent être pris en charge doivent être des valeurs valides dans la méthode filter_list (différents environnements de serveur peuvent varier). Les supports possibles incluent :


int
 boolean
 float
validate_regexp
validate_url
validate_email
validate_ip
 string
stripped
encoded
special_chars
unsafe_raw
email
url
number_int
number_float
magic_quotes
callback
Copier après la connexion

Dans certains cas particuliers, nous ne souhaitons effectuer aucun filtrage, même si DEFAULT_FILTER a été défini, vous pouvez utiliser :


I(&#39;get.name&#39;,&#39;&#39;,NULL);
Copier après la connexion

Une fois le paramètre de filtrage réglé à NULL, cela signifie qu'aucun filtrage ne sera plus effectué.

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. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

Utilisation de distinct dans Thinkphp

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 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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Comment exécuter le projet thinkphp Comment exécuter le projet thinkphp Apr 09, 2024 pm 05:33 PM

Pour exécuter le projet ThinkPHP, vous devez : installer Composer ; utiliser Composer pour créer le projet ; entrer dans le répertoire du projet et exécuter php bin/console serve ; visiter http://localhost:8000 pour afficher la page d'accueil.

Il existe plusieurs versions de thinkphp Il existe plusieurs versions de thinkphp Apr 09, 2024 pm 06:09 PM

ThinkPHP dispose de plusieurs versions conçues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

Comment exécuter thinkphp Comment exécuter thinkphp Apr 09, 2024 pm 05:39 PM

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Lequel est le meilleur, Laravel ou thinkphp ? Lequel est le meilleur, Laravel ou thinkphp ? Apr 09, 2024 pm 03:18 PM

Comparaison des performances des frameworks Laravel et ThinkPHP : ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

Comment installer thinkphp Comment installer thinkphp Apr 09, 2024 pm 05:42 PM

Étapes d'installation de ThinkPHP : Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Nov 22, 2023 pm 12:01 PM

"Suggestions de développement : comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones" Avec le développement rapide de la technologie Internet, les applications Web ont des exigences de plus en plus élevées pour gérer un grand nombre de requêtes simultanées et une logique métier complexe. Afin d'améliorer les performances du système et l'expérience utilisateur, les développeurs envisagent souvent d'utiliser des tâches asynchrones pour effectuer certaines opérations chronophages, telles que l'envoi d'e-mails, le traitement des téléchargements de fichiers, la génération de rapports, etc. Dans le domaine de PHP, le framework ThinkPHP, en tant que framework de développement populaire, offre des moyens pratiques d'implémenter des tâches asynchrones.

Quelles sont les performances de thinkphp ? Quelles sont les performances de thinkphp ? Apr 09, 2024 pm 05:24 PM

ThinkPHP est un framework PHP hautes performances présentant des avantages tels que le mécanisme de mise en cache, l'optimisation du code, le traitement parallèle et l'optimisation des bases de données. Les tests de performances officiels montrent qu'il peut gérer plus de 10 000 requêtes par seconde et qu'il est largement utilisé dans les sites Web à grande échelle et les systèmes d'entreprise tels que JD.com et Ctrip dans les applications réelles.

Service RPC basé sur ThinkPHP6 et Swoole pour implémenter la fonction de transfert de fichiers Service RPC basé sur ThinkPHP6 et Swoole pour implémenter la fonction de transfert de fichiers Oct 12, 2023 pm 12:06 PM

Le service RPC basé sur ThinkPHP6 et Swoole implémente la fonction de transfert de fichiers Introduction : Avec le développement d'Internet, le transfert de fichiers est devenu de plus en plus important dans notre travail quotidien. Afin d'améliorer l'efficacité et la sécurité du transfert de fichiers, cet article présentera la méthode d'implémentation spécifique de la fonction de transfert de fichiers basée sur le service RPC basé sur ThinkPHP6 et Swoole. Nous utiliserons ThinkPHP6 comme framework Web et utiliserons la fonction RPC de Swoole pour réaliser le transfert de fichiers entre serveurs. 1. Norme environnementale

See all articles