


Le problème cumulatif et la solution des fonctions de rappel dans la boucle foreach
Cet article traite des problèmes de résultats cumulatifs qui peuvent survenir lors de l'utilisation des fonctions de rappel dans des boucles foreach
et fournit des solutions correspondantes.
Description du problème
Lorsque vous utilisez foreach
pour parcourir les données et appeler la fonction de rappel getchildareaid
pour obtenir l'ID de sous-région, il est constaté que les résultats sont accumulés. Le code est le suivant:
foreach ($ villes comme $ key => $ val) { $ AreaDarr = getChildAreAid ($ val ['id']); $ Result [$ val ['name']] = $ worker :: où ('area_id', 'in', $ wareDarr) -> count (); }
La fonction de rappel getchildareaid
est définie comme suit:
fonction getchildaiid ($ id) { zone de $ statique; $ Area = $ Area ?? new \ app \ commun \ Model \ Area; $ result = collection ($ Area-> où (['pid' => $ id]) -> commander ('id desc') -> select ()) -> toArray (); $ Res statique = []; if ($ result) { foreach ($ résultat comme $ key => $ val) { $ res [] = $ val ['id']; getChildAreaiid ($ val ['id']); } } retour $ res; }
Le problème est que la fonction getchildareaid
utilise la variable statique $res
, ce qui fait accumuler le résultat précédent à chaque fois qu'il est appelé, plutôt que de calculer indépendamment à chaque fois.
Analyse des problèmes
static $res = [];
déclare une variable statique dans la fonction getchildareaid
. Les variables statiques ne seront pas détruites une fois l'appel de fonction terminé et leurs valeurs seront conservées dans les appels ultérieurs. Par conséquent, chaque fois que foreach
appelle getchildareaid
, $res
accumule de nouveaux résultats, ce qui conduit finalement à une erreur dans le résultat.
Solution
Pour résoudre ce problème et éviter d'utiliser des variables statiques, les deux méthodes suivantes peuvent être utilisées:
Réécrivez la fonction, utilisez des variables locales: créez une nouvelle fonction, au lieu d'utiliser la variable statique
$res
, mais utilisez des variables locales pour stocker les résultats de chaque appel.Modifiez les fonctions existantes et éliminez les variables statiques: modifiez la fonction
getchildareaid
, supprimez la variable statique$res
et renvoyez un nouveau tableau lorsqu'il est appelé récursivement pour éviter l'accumulation de résultats. La fonction modifiée est la suivante:
fonction getchildAreAid ($ id) { $ area = new \ app \ Common \ Model \ Area; $ result = collection ($ Area-> où (['pid' => $ id]) -> commander ('id desc') -> select ()) -> toArray (); $ res = []; if ($ result) { foreach ($ résultat comme $ key => $ val) { $ res [] = $ val ['id']; $ res = array_merge ($ res, getChildAreAid ($ val ['id'])); } } retour $ res; }
Cette fonction modifiée crée un nouveau tableau $res
chaque fois qu'il est appelé récursivement et fusionne les résultats récursifs dans les $res
actuels, évitant ainsi le problème de l'accumulation de résultats. Quelle solution à choisir dépend de la structure globale et de la maintenabilité du code. Habituellement, la réécriture des fonctions est plus claire et plus facile à comprendre.
Grâce aux méthodes ci-dessus, le problème des résultats de la fonction de rappel l'accumulation dans foreach
peut être résolu efficacement, garantissant que le résultat correct peut être obtenu chaque fois que la fonction de rappel est appelée.
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!

PhpSessionsCanstorestrings, Numbers, Arrays, Andobject.1.Strings: TextDatalikeUserames.2.Numbers: IntegersorFloatsForCounters.3.arrays: listslikeshoppingcarts.4.Objects: complexestructuresthataReSerialized.

TostartaphpSession, usessession_start () aTTheScript'sbeginning.1) PlaceItBeForeanyOutputToSetTheSessionCooKie.2) USESSIONSFORUSERDATALIKELOGINSTATUSORSHOPPINGSCARS.3) RegegeraSesessionIdStopreventfixationAtTACKS.4)

La régénération de session fait référence à la génération d'un nouvel ID de session et à l'invalidation de l'ancien ID lorsque l'utilisateur effectue des opérations sensibles en cas d'attaques fixes de session. Les étapes de mise en œuvre incluent: 1. Détectez les opérations sensibles, 2. Générer un nouvel ID de session, 3. Détruiser l'ancien ID de session, 4. Mettre à jour les informations de session côté utilisateur.

Les séances PHP ont un impact significatif sur les performances des applications. Les méthodes d'optimisation incluent: 1. Utilisez une base de données pour stocker les données de session pour améliorer la vitesse de réponse; 2. Réduire l'utilisation des données de session et stocker uniquement les informations nécessaires; 3. Utilisez un processeur de session non bloquant pour améliorer les capacités de concurrence; 4. Ajustez le temps d'expiration de la session pour équilibrer l'expérience utilisateur et la charge du serveur; 5. Utilisez des séances persistantes pour réduire le nombre de données de lecture et d'écriture.

PhpsessionsareServer-côté, whileCookiesareclient-Side.1) SessionStoredataontheServer, aremoresecure, ethandleLargerData.2) CookiesstoredataontheClient, ArelessSecure, andlimitedIzeSize.USESESSIONSFORSENSEDATAANDCOOKIESFORNONNORNE-SENSENSITION, Client-Sidedata.

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit


Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP
