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

Java EE Discussion :

Invocation à partir d'un client lourd


Sujet :

Java EE

  1. #21
    Membre éprouvé

    Profil pro
    Inscrit en
    Mars 2002
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2002
    Messages : 652
    Points : 1 151
    Points
    1 151
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ConverterRemoteHome home = (ConverterRemoteHome)PortableRemoteObject.narrow(objRef, ConverterRemoteHome.class);
    Tu utilise, rien que dans cette ligne, 3 fois la référence ConverterRemoteHome


    Regarde les specs des EJB et le rôle des container EJB.

    Le container a pour responsabilité de compiler les stubs (au besoin) des EJB et de les déployer ensuite !
    Optionnelement, tu peu demander à ton container de te générer le jar-client qui contiend les interfaces et les stubs mais aucune classe d'implémentation !
    Il faut bien que le client ai de quoi "parler" avec le serveur non ?

    As tu déjà essayer de lancer ton serveur d'un coté et ton client de l'autre "en dehors de ton projet (eclipse je suppose)" ?
    Clic me...
    CV en ligne

    Il y a 10 types de personnes, celui qui connait le binaire, et l'autre...

    Pas de réponse en MP...Merci

  2. #22
    Membre du Club
    Inscrit en
    Septembre 2004
    Messages
    124
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 124
    Points : 48
    Points
    48
    Par défaut
    Oui ok tu as raison...
    C'est juste que j'ai du mal a m'imaginer clairement car je ne les "vois" pas ces fichiers...
    Donc le container compile et déploie les stubs... ok
    Mais je ne comprends tjrs pas mon erreur... Du moins le nom de la classe de l'objet que je recupere est
    Nom de la classe de l'objet JNDI : com.sun.corba.se.internal.iiop.CDRInputStream_1_0$1
    et devrait plutot etre de type :
    converter._ConverterRemoteHome_DynamicStub
    Non?

  3. #23
    Membre éprouvé

    Profil pro
    Inscrit en
    Mars 2002
    Messages
    652
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Mars 2002
    Messages : 652
    Points : 1 151
    Points
    1 151
    Par défaut
    Celà dépend du serveur avec lequel tu travail, je ne saurais pas te dire !
    La seconde me semble plus logique en effet !

    Quel nom JNDI utilise tu pour le lookup ?
    Ton EJB as t'il déjà fonctionné ?
    Ton ejb déployé sous ce nom correspond à ton EjbConverter ?
    essaye de le redéployer après l'avoir desinstallé, on ne sais jamais !
    Peut être que la home enregistrée sous ce nom ne correspond pas à ton EJB
    Est-tu sure d'être sur TON naming ? ( a prioris oui, tu utilise localhost il me semble)
    L'interface déployée est elle la "même" dans la "même version" que celle que tu utilise coté client ?
    Clic me...
    CV en ligne

    Il y a 10 types de personnes, celui qui connait le binaire, et l'autre...

    Pas de réponse en MP...Merci

  4. #24
    Membre du Club
    Inscrit en
    Septembre 2004
    Messages
    124
    Détails du profil
    Informations forums :
    Inscription : Septembre 2004
    Messages : 124
    Points : 48
    Points
    48
    Par défaut
    Mon SA est celui de sun...
    Ce qui est bizarre c'est que je liste tous les EJBs présents et ils ont tous le même nom de classe d'objet...
    Pour effectuer mon lookup j'utilise un "ejb/ConverterBean"... j'ai redéployé mais ca ne change rien... et j'ai la meme erreur si j'essai avec un autre EJB
    D'ailleurs pour un autre EJB, j'ai un client ou l'on initialise le contexte uniquement avec Context initial = new InitialContext(); et cela fonctionne...
    pourquoi est-ce que moi quand j'initialise mon contexte avec com.sun.jndi.cosnaming.CNCtxFactory ca ne fonctionne pas alors que j'arrive a lister les EJBs correctement!

  5. #25
    Membre éprouvé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 064
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 064
    Points : 1 053
    Points
    1 053
    Par défaut
    Désolé de remonter un post vieux de plus d'un an mais j'ai exactement le même problème que celui cité ici.
    Voici mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
                java.util.Hashtable hash = new java.util.Hashtable();
                hash.put(javax.naming.Context.INITIAL_CONTEXT_FACTORY, "com.sun.jndi.cosnaming.CNCtxFactory");
                hash.put(javax.naming.Context.PROVIDER_URL, "iiop://localhost:3700");
                javax.naming.Context context = new javax.naming.InitialContext(hash);
                Object ref = context.lookup("ejb/CholiBean");
                choli.CholiRemoteHome home = (choli.CholiRemoteHome)javax.rmi.PortableRemoteObject.narrow(ref, choli.CholiRemoteHome.class);
                choli.CholiRemote obj = home.create();
                this.jLabel1.setText(obj.sayHello());
    qui effectivement provoque lui aussi une ClassCastException. J'utilise le serveur 8.1 de sun avec netbeans.
    Ce qui est étrange c'est que si je laisse le InitialContext utiliser les paramètres par défaut ca fonctionne. Il utilise alors (je crois) la classe com.sun.enterprise.naming.SerialInitContextFactory. L'ennui c'est que cette classe la je n'arrive pas à la configurer pour paramétrer l'adresse du serveur ! (elle utilise par défaut le localhost)
    Si l'auteur de ce post voit ce message, ce serait sympa de m'expliquer comment il a fait.
    Merci d'avance.

  6. #26
    Membre éprouvé
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 064
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 064
    Points : 1 053
    Points
    1 053
    Par défaut
    Bon, pour ceux que ca interesserait, j'ai trouvé comment faire pour résoudre ce problème.
    Il suffit de taper
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    javax.naming.Context context = new javax.naming.InitialContext();
    et donc de laisser java utiliser sa classe par défaut. Ensuite c'est dans la méthode lookup qu'on indique la machine distante. Par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Object ref = context.lookup("iiop://localhost:3700/ejb/CholiBean");

Discussions similaires

  1. Invocation d'un service web à partir d'un client Java
    Par epsilonna dans le forum Services Web
    Réponses: 0
    Dernier message: 21/12/2011, 13h51
  2. Réponses: 1
    Dernier message: 28/02/2007, 17h33
  3. Affichage d'une image à partir d'un client
    Par Aldur dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 03/01/2006, 10h44
  4. problème d'accèes à firebird sà partir d'un client
    Par vbcasimir dans le forum Connexion aux bases de données
    Réponses: 2
    Dernier message: 10/05/2005, 08h36
  5. Application Intranet ou Application type client lourd
    Par oursbleu dans le forum Langages de programmation
    Réponses: 4
    Dernier message: 03/02/2005, 22h00

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