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

API standards et tierces Java Discussion :

[JMX] Appel d'une méthode distante avec retour d'objet complexe


Sujet :

API standards et tierces Java

  1. #1
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut [JMX] Appel d'une méthode distante avec retour d'objet complexe
    Bonjour,

    Je cherche a comprendre une erreur que j'obtiens en faisant un appel distant par JMX.

    La syntaxe d'appel est assez simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            ListenersRegistryMBean proxy = (ListenersRegistryMBean) MBeanServerInvocationHandler.newProxyInstance(server, new ObjectName(LISTENER_REGISTRY_OBJ_NAME), ListenersRegistryMBean.class, false);
                     ReturnMemento rm = proxy.addListener(null);
    L'erreur n'est pas reproductible dans un simple main mais uniquement dans l'appli web qui utilise ce bout de code.

    Ca parle de SecurityManager comme dans ce post http://www.developpez.net/forums/d19...rmic-packages/

    mais le fait de changer le SecurityManager dans mon appli web et d'avoir a modifier la politique de sécurité de l'appli ne me branche pas des masses.
    Je ne comprends pas pourquoi je peux réaliser cette opération dans un main (MC4J ou la jconsole y arrive aussi) mais pas dans mon appli web.

    Une idée ?

    [17:04:31.662][info][talledLocalContainer] Caused by: java.rmi.UnmarshalException: java.lang.ClassNotFoundException: fr.sgf.wit.persistence.model.Listener (no security manager: RMI class loader disabled); nested exception is:
    [17:04:31.662][info][talledLocalContainer] java.lang.ClassNotFoundException: fr.sgf.wit.persistence.model.Listener (no security manager: RMI class loader disabled)
    [17:04:31.662][info][talledLocalContainer] at javax.management.remote.rmi.RMIConnectionImpl$6.run(RMIConnectionImpl.java:1599)
    [17:04:31.677][info][talledLocalContainer] at java.security.AccessController.doPrivileged(Native Method)
    [17:04:31.677][info][talledLocalContainer] at javax.management.remote.rmi.RMIConnectionImpl.unwrap(RMIConnectionImpl.java:1586)
    [17:04:31.677][info][talledLocalContainer] at javax.management.remote.rmi.RMIConnectionImpl.access$600(RMIConnectionImpl.java:81)
    [17:04:31.693][info][talledLocalContainer] at javax.management.remote.rmi.RMIConnectionImpl$7.run(RMIConnectionImpl.java:1631)
    [17:04:31.693][info][talledLocalContainer] at java.security.AccessController.doPrivileged(Native Method)
    [17:04:31.693][info][talledLocalContainer] at javax.management.remote.rmi.RMIConnectionImpl.unwrap(RMIConnectionImpl.java:1627)
    [17:04:31.693][info][talledLocalContainer] at javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:766)
    [17:04:31.693][info][talledLocalContainer] at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    [17:04:31.708][info][talledLocalContainer] at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    [17:04:31.708][info][talledLocalContainer] at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    [17:04:31.708][info][talledLocalContainer] at java.lang.reflect.Method.invoke(Method.java:585)
    [17:04:31.724][info][talledLocalContainer] at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:294)
    [17:04:31.724][info][talledLocalContainer] at sun.rmi.transport.Transport$1.run(Transport.java:153)
    [17:04:31.724][info][talledLocalContainer] at java.security.AccessController.doPrivileged(Native Method)
    [17:04:31.724][info][talledLocalContainer] at sun.rmi.transport.Transport.serviceCall(Transport.java:149)
    [17:04:31.724][info][talledLocalContainer] at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:466)
    [17:04:31.724][info][talledLocalContainer] at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:707)

  2. #2
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut
    en fait si, c'est bien reproductible dans un main tout bête, c'est juste que dans le main je passais un argument null et ca passait sans souci. Or c'est justement la classe que je transmets qui est non trouvé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
            JMXConnectionsManager manager = new JMXConnectionsManager(new CommonsJMXConfiguration());
            MBeanServerConnection server  = manager.getJMXConnection(new JMXConnectionInfo("****", ****));
     
            ListenersRegistryMBean proxy = (ListenersRegistryMBean) MBeanServerInvocationHandler.newProxyInstance(server, new ObjectName(LISTENER_REGISTRY_OBJ_NAME), ListenersRegistryMBean.class, false);
     
            // Listener listener = new Listener ();
            // listener.setName("test");
            // listener
            //    
     
            ReturnMemento rm = proxy.addListener(new Listener());
     
            System.out.println(rm);
    [18:41:10.242][info][talledLocalContainer] Caused by: java.lang.ClassNotFoundException: fr.sgf.wit.persistence.model.Listener (no security manager: RMI class loader disabled)
    [18:41:10.242][info][talledLocalContainer] at sun.rmi.server.LoaderHandler.loadClass(LoaderHandler.java:371)
    [18:41:10.242][info][talledLocalContainer] at sun.rmi.server.LoaderHandler.loadClass(LoaderHandler.java:165)
    D'après la doc http://java.sun.com/developer/JDCTec...01/tt0227.html ou un lien sur le forum spring http://forum.springsource.org/showthread.php?t=38231 ca ne doit arriver que si une classe manque d'un des deux côtés. Or ce n'est pas mon cas...

  3. #3
    Rédacteur

    Homme Profil pro
    Geek entrepreneur
    Inscrit en
    Novembre 2004
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Geek entrepreneur

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 224
    Points : 2 373
    Points
    2 373
    Par défaut
    ok, j'ai fini par trouver. Apparemment la convention de nommage entre le MBean et l'implémentation n'était pas correcte.
    Cependant avec spring ca ne posait pas de problème pour exposer le bean.
    L'erreur du Classnotfoundexception est complètement mystique puisque ca ne réfère pas a la vraie erreur et surtout que ca passe avec un argument null...

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

Discussions similaires

  1. Appel de méthode distante avec SOAP
    Par bobo21 dans le forum Services Web
    Réponses: 2
    Dernier message: 13/02/2009, 17h44
  2. appel d'une page fille et retour page mère avec données
    Par beabea dans le forum Général Dotnet
    Réponses: 0
    Dernier message: 09/01/2009, 17h53
  3. Appel d'une méthode distante
    Par jean-pierre96 dans le forum Coldfusion
    Réponses: 1
    Dernier message: 22/05/2008, 09h07
  4. appel d'une méthode avec plusieurs paramètres
    Par soujava dans le forum Débuter avec Java
    Réponses: 2
    Dernier message: 12/05/2008, 00h30
  5. Réponses: 2
    Dernier message: 06/12/2005, 10h41

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