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

JSF Java Discussion :

Problème de Design Pattern


Sujet :

JSF Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    102
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 102
    Par défaut Problème de Design Pattern
    Chers tous,

    J'ai un petit souci en JSF, que faire quand les entity beans ne coresspondent pas à la vue. Je m'explique :

    Imaginons, j'ai un entity User(userID, password) et je souhaite afficher dans la vue avec une datatable (userID, password, +qqch d'autre). Le truc c'est que je ne veux pas modifier mon entity car ce n'est pas chose à faire. Mais alors, ce nouvel objet, je dois le mettre dans une couche au dessus des EJB?

    genre :

    JSF Managed beans -> business object -> session bean -> entity bean

    Merci pour vos réponses !

  2. #2
    Membre Expert
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    2 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 938
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    J'ai un petit souci en JSF, que faire quand les entity beans ne coresspondent pas à la vue
    Sur une contrainte architecturelle, un entity bean n'est pas censé correspondre completement à une vue,ce sont des objets de la 3e couche, si ca peut t'aider tu peux declarer des attributs en transient, primitive ordonnant à JPA de ne pas les persister. ca repond à ta question?

  3. #3
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    102
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 102
    Par défaut
    Merci pour ta réponse. Je connaissait déjà la possibilité d'annoter @transient les attributs des entity beans pour skipper la persistance.

    Cependant, je ne crois pas qu'il soit judicieux de procéder de la sorte. Serait-il plus judicieux de créer une couche au dessus des stateless beans comprenant les objets-vue?

    Tous les avis sont les bienvenus !

  4. #4
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 313
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 313
    Billets dans le blog
    1
    Par défaut
    Tu peux utiliser les DTO (Data Transfert Object), je trouve que c'est ce qu'il y a de mieux pour ce genre de problématique (et d'autres mais c'est un autre débat).
    Du coup, ton EJB stateless/statefull renvoie une liste d'objets DTO, ceux-ci sont totalement indépendants de la persistance (charge à la méthode appelée de récupérer toutes les informations voulues).

    Je suis d'accord avec toi pour ce qui est de rajouter des propriétés @Transient, ça n'a pas trop de sens dans la mesure où le chargement serait complexifié, on les utilise plutôt pour des données calculées par rapport à des attributs de l'entity (c'est mon avis en tout cas )
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    102
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 102
    Par défaut
    Un tout grand merci pour ta réponse. Donc si j'ai bien compris, on a :

    - une couche entity (objets persistés)
    - une couche dto
    - une couche dao (query sur les entity retournant des dto)
    - une couche jsf managed beans (injection des ejb qui retournent les dto)

    Donc en gros, un dto est quasimment un objet sans méthodes, je me trompe ?
    (sans les get/set évidemment).

  6. #6
    Membre confirmé
    Inscrit en
    Avril 2006
    Messages
    102
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 102
    Par défaut
    Une remarque, est-ce que les DTO's doivent normalement étendre (extends) les entity beans?

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

Discussions similaires

  1. Problème avec le design pattern visitor
    Par RT222 dans le forum Langage
    Réponses: 5
    Dernier message: 13/05/2012, 20h28
  2. Réponses: 2
    Dernier message: 26/12/2010, 22h08
  3. Problème Design Pattern : Help
    Par donkeyquote dans le forum C++
    Réponses: 5
    Dernier message: 14/01/2008, 09h54
  4. Problème d'accessibilité avec le design patterns MVC
    Par radical_bombtracks dans le forum JSF
    Réponses: 5
    Dernier message: 24/07/2007, 13h15
  5. Réponses: 5
    Dernier message: 10/05/2007, 16h03

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