IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Positionner mysqli en global


Sujet :

Langage PHP

  1. #1
    Invité
    Invité(e)
    Par défaut Positionner mysqli en global
    Bonjour,
    Je débute dans le côté objet de PHP.
    Pour faire simple, j'ai 3 fichiers :

    connexion.inc.php qui me permet de me connecter à la base via cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $mysqli = new mysqli($ser, $usr, $pass, $bd);
    session.inc.php qui contient ma fonction php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
      function retlogin () {
     /* retourne le login de la session courante */
     
    	$id_user=retiduser();
    	$log = "SELECT login FROM utilisateurs WHERE id_user = $id_user ";
    	if ($lelog=$mysqli->query($log)){
     
    		if ($obj=$lelog->fetch_object()) {
    			return $obj->login;
    		} else {
    			return false;
    		}
    	}
    }

    index.php, ma page php appellante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     include ("connexion.inc.php");
     include ("session.inc.php");
     
     echo retlogin();

    Et ça ne marche pas, ça ne m'affiche pas mon login.

    Par contre, si je passe en paramètre de la fonction "$mysqli" cela fonctionne bien (côté page php appellante, et côté fonction)

    Cela fonctionnera-t-il si j'arrive à passer $mysqli en variable globale ?
    Et si oui, comment faire ?

    Merci d'avance pour votre aide

    Cyann
    Dernière modification par Bovino ; 19/12/2013 à 08h04. Motif: Balises [code], pas [quote] !

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Invité
    Invité(e)
    Par défaut
    $mysqli n'est pas réellement une variable, mais une instance de mysqli.
    De plus elle n'est pas déclarée dans une fonction (mais dans mon fichier connexion.inc.php).

    J'ai quand meme tenté de rajouter le global $mysqli dans connexion.inc.php
    Et dans ma fonction de mettre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    global $mysqli->query()
    Mais ça ne fonctionne pas non plus

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    global $mysqli->query()
    Tu as vraiment lu ce qu'il y a dans le lien de la FAQ ?

    C'est $mysqli qui doit être global

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    global $mysqli;
    $lelog=$mysqli->query($log);
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    $mysqli EST une variable.

    C'est
    et c'est dans la fonction qui a besoin de l'utiliser qu'il faut le mettre.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  6. #6
    Invité
    Invité(e)
    Par défaut
    Merci beaucoup pour votre aide (et patiente ^^)
    Ça marche beaucoup mieux.

    Je n'avais pas bien compris la mise en place de variable globale.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Comment positionner des blocs fixed dans un autre bloc global ?
    Par jalex-jalex dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 08/10/2008, 06h21
  2. [TSynMemo] Positionnement par ligne et colonne
    Par Mercilius dans le forum Composants VCL
    Réponses: 9
    Dernier message: 16/04/2003, 16h22
  3. Fichier de fonctions globales
    Par PEM dans le forum C++Builder
    Réponses: 5
    Dernier message: 10/07/2002, 21h35
  4. variables locales ou globales ???
    Par elvivo dans le forum C
    Réponses: 13
    Dernier message: 03/07/2002, 08h22
  5. les variables globales static
    Par gRRosminet dans le forum C
    Réponses: 8
    Dernier message: 27/04/2002, 08h34

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo