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 :

PHP bean et DAO


Sujet :

Langage PHP

  1. #1
    Membre averti
    Inscrit en
    Septembre 2010
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 57
    Par défaut PHP bean et DAO
    Bonjour,

    Pour un projet j'ai mis en place une archi MVC avec des DAO. Au passage je viens du java J2EE donc si une telle archi n'a pas sa place en PHP merci de me le dire ;-)).

    J'ai un agent qui est dans un site (agence si vous préférez).
    J'en ai déduis le bean AGENT (version simplifiée):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    class Agent{
            public $id;
    	public $site;
     
    	/* setters */
     
    	/* getters */
    }
    et le bean SITE :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    class Site{
     
    	public $id;
    	public $nom;
     
    	/* setters */
    	/* getters */
    }
    Voici mon AgentDAO :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    class AgentDAO{
     
    	public $conn;
    	public $siteDAO;
     
    	function __construct() {
    		$this->conn = SingletonConnexion::getInstance();
    		$this->siteDAO = new SiteDAO();
        }
     
       public function getAgentParCodeAgent($codeAgent){
    		$stmt = $this->conn->prepare("SELECT * FROM agent WHERE code_agent LIKE :codeAgent");
    		$stmt->bindParam(":codeAgent",$codeAgent);
    		$stmt->execute();
    		$_agent = $stmt->fetch();
     
    		$agent = $this->initAgent($_agent);
    		return $agent;
    	}
     
    	private function initAgent($_agent){
    		$agent = new Agent();
    		$agent->setId($_agent["id_agent"]);		
    		$agent->setCode($_agent["code_agent"]);		
    		$agent->setSexe($_agent["sexe_agent"]);		
    		$agent->setPrenom($_agent["prenom_agent"]);		
    		$agent->setNom($_agent["nom_agent"]);		
    		$agent->setNumero($_agent["numero_agent"]);		
    		$agent->setOrdre($_agent["ordre_agent"]);		
    		$agent->setRue($_agent["rue_agent"]);		
    		$agent->setComplement($_agent["complement_adresse_agent"]);		
    		$agent->setCp($_agent["cp_agent"]);		
    		$agent->setCommune($_agent["commune_agent"]);		
    		$agent->setDtnais($_agent["date_naissance_agent"]);		
    		$agent->setEmail($_agent["email_agent"]);		
    		$agent->setDateEntree($_agent["date_entree_agent"]);		
    		$agent->setDatePermisConduire($_agent["date_permis_conduire_agent"]);	
    		echo $_agent["site_agent"];
    		$agent->setSite($this->siteDAO->getSiteParIdSite($_agent["site_agent"]);	
    		return $agent;
    	}
     
    	public function __destruct(){}
     
    }
    et mon SiteDAO :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    class SiteDAO{
     
    	public $conn;
     
    	function __construct() {
    		$this->conn = SingletonConnexion::getInstance();
        }
     
    	public function getSiteParIdSite($idSite){
     
    		$stmt = $this->conn->prepare("SELECT * FROM site WHERE id_site = :idSite");
    		$stmt->bindParam(":idSite",$idSite);
    		$stmt->execute();
    		$_site = $stmt->fetch();
     
    		$site = new Site();
    		$site->setId($_site["id_site"]);
    		$site->setNom($_site["nom_site"]);
    		print_r($site);
    		/**/
    		return $site;
     
    	}
     
    	public function __destruct(){}
     
    }
    Problème, quand je fais un getAgentParCodeAgent, tout passe juqu'à l'accès à siteDAO (quand le met à jour la variable $site de l'agent). Je l'ai affichée mais elle est vide (j'ai l'impression qu'il ne l'instancie pas).

    Merci d'avance

  2. #2
    Expert confirmé

    Avatar de FirePrawn
    Homme Profil pro
    Consultant technique
    Inscrit en
    Mars 2011
    Messages
    3 179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Consultant technique

    Informations forums :
    Inscription : Mars 2011
    Messages : 3 179
    Par défaut
    Bonjour,

    Tu pourrais mettre le code où tu appelles les méthodes ?
    Avant toute chose : lire le mode d'emploi du forum et ses règles.
    Je ne réponds pas aux questions techniques en MP.

  3. #3
    Membre averti
    Inscrit en
    Septembre 2010
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 57
    Par défaut
    Ma page d'appel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    <?php
    session_start();
    include_once("../../../_controleur/AgentControleur.php");
    include_once("../../../_modele/dao/AgentDAO.php");
    include_once("../../../_controleur/SiteControleur.php");
    include_once("../../../_modele/dao/SiteDAO.php");
    include_once("../../../_modele/bean/Agent.php");
    include_once("../../../_modele/bean/Site.php");
    include_once("../../../Outils/BaseDeDonnees/objet/SingletonConnexion.php");
     
    $_agent = new AgentControleur();
    ?>
    <html>
    <title>test</title>
    </head>
    <body>
     
    <?php
    $codeAgent = "2881";
    $agent = $_agent->getAgentParCodeAgent($codeAgent);
    echo $agent->getNom()."<br/>"."<br/>";
    ?>
    </body>
    </html>
    Mes controleurs ne font rien de particulier (pour l'instant), ils appellent juste mes DAO.

    Merci

  4. #4
    Membre averti
    Inscrit en
    Septembre 2010
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 57
    Par défaut
    Euh je pense avoir fait une boulette qqpart car avec ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $site = $this->siteDAO->getSiteParIdSite($_agent["site_agent"]);
    $agent->setSite($site);
    à la place de celui ci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $agent->setSite($this->siteDAO->getSiteParSite($_agent["site_agent"]);
    ça marche !

    Quelqu'un saurait me dire pourquoi?

  5. #5
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 931
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 931
    Par défaut
    Citation Envoyé par maxwell374 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $agent->setSite($this->siteDAO->getSiteParSite($_agent["site_agent"]);
    Il manque une parenthèse fermante.

  6. #6
    Membre averti
    Inscrit en
    Septembre 2010
    Messages
    57
    Détails du profil
    Informations forums :
    Inscription : Septembre 2010
    Messages : 57
    Par défaut
    Ok je sors !

  7. #7
    Membre éprouvé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 448
    Par défaut
    hello,

    Dans AgentDAO::getAgentParCodeAgent

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
       public function getAgentParCodeAgent($codeAgent){
    		$stmt = $this->conn->prepare("SELECT * FROM agent WHERE code_agent LIKE :codeAgent");
    		$stmt->bindParam(":codeAgent",$codeAgent);
    		$stmt->execute();
    		$_agent = $stmt->fetch();
     
    		$agent = $this->initAgent($_agent);
    		return $agent;
    	}
    Tu ne vérifies pas que ton $stmt->fetch est différent de false.
    Donc en fait, sa peux amener à créer un agent vide.

    Dans Agent,
    Tu ne nous donne pas le code de Agent::getNom et Agent::setNom. Je sais, ses méthodes sont triviales mais pour déterminer le dysfonctionnement de ton programme, il en faut toutes les pièces..

    Déjà des débuts de piste.

    Autrement, je trouve ton code extrêmement lourd et compliqué !!!!!
    Il n'y à qu'à voir, dès la première requête tu te galères... Et c'est compréhensible.

    Pourquoi ne pas te tourner vers un outil dédié à cela ?
    Tels que par exemple Doctrine 1/2 (j'en suis pas fan, mais sa fera le boulot : ), ou bien RedBean (je préfère) accompagné de DomainObject.
    Ou n'importe quoi d'autre qui te conviendra plus !!


    a+

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

Discussions similaires

  1. Session bean et DAO
    Par developpCathy dans le forum Général Java
    Réponses: 1
    Dernier message: 21/06/2012, 17h49
  2. [Hibernate 2] Bean session et persistance DAO
    Par archer dans le forum Hibernate
    Réponses: 4
    Dernier message: 19/04/2010, 16h55
  3. confusion entre entiy bean , dto et dao
    Par riadhhwajdii dans le forum Persistance des données
    Réponses: 6
    Dernier message: 26/11/2009, 18h02
  4. managed bean et dao et scope request
    Par *alexandre* dans le forum JSF
    Réponses: 2
    Dernier message: 30/09/2008, 08h13
  5. managed bean et dao
    Par *alexandre* dans le forum JSF
    Réponses: 5
    Dernier message: 16/09/2008, 09h10

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