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 Discussion :

Problème JNDI et class loaders "perso"


Sujet :

Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 11
    Points : 11
    Points
    11
    Par défaut Problème JNDI et class loaders "perso"
    Bonjour,

    J'ai un souci :-) Pour schématiser:

    - une classe principale A utilise un URLClassLoader pour charger des classes dynamiquement. Ce class loader contient, dans son "classpath", trois librairies: B.jar contenant une classe B, C.jar contenant une classe lambda C et enfin D.jar contenant une classe D qui se trouve etre un InitialContextFactory.

    (en l'occurence dans la réalité D.jar est weblogic.jar et D est weblogic.jndi.WLInitialContextFactory mais je ne pense pas que ce soit important car le souci me semble plus générique)

    - A instancie la classe B pour l'utiliser, à l'aide du class loader défini ci-dessus.

    - B, quand à lui, instancie la classe C directement (à l'aide d'un simple new): aucun souci, ça marche très bien (j'en déduit que le classe loader par défaut utilisé par B pour charger C est celui qui a servi à le charger lui même depuis A...)

    - Plus loin, B va instancier D à travers JNDI et fait donc un new InitialContext en lui passant le nom complet avec package de la classe D dans la property "java.naming.factory.initial"

    Et là.... c'est le drame! Ca plante en me disant: "class not found: D"...

    Je rappel que D.jar est pourtant bien dans le classpath du class loader ayant servi à charger B. J'en déduit donc que le class loader par défaut, s'il est bien utilisé pour instancier des classes classiquement depuis B (avec un simple new, comme on l'a vu avec la classe C), il n'est par contre pas transmis par défaut à InitialContext afin d'être utilisé pour charger la factory...

    Bref ma question est: comment signifier à InitialContext qu'il doit utiliser mon class loader? Est-ce seulement possible?

    Merci d'avance!

  2. #2
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    essaie de faire un Thread.currentThread().setContextClassloader(classloader). Le doc de sun n'est pas explicite quand à la manière dont initialContext détermine le classloader à utiliser pour sa factory, mais c'est probablement çà

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 11
    Points : 11
    Points
    11
    Par défaut
    Bonjour,

    Merci du tuyau mais... a quel endroit dois-je le mettre? Dans la classe B, avant le new InitialContext?

    Par ailleurs je vois en javadoc du Thread.getContextClassLoader():

    Returns the context ClassLoader for this Thread. The context ClassLoader is provided by the creator of the thread for use by code running in this thread when loading classes and resources. If not set, the default is the ClassLoader context of the parent Thread. The context ClassLoader of the primordial thread is typically set to the class loader used to load the application.


    Donc en théorie il devrait bel et bien utiliser par défaut mon ClassLoader vu que c'est celui qui a été utilisé pour charger B... A moins que ça ne soit un probleme de droits? (SecurityManager...) Je vais regarder ça.

    Merci,

  4. #4
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    par défaut, il n'utilise pas le classloader qui a servit à charger le thread, mais le "contextclassloader" du "thread" "parent" (en l'occurence dans ton cas, celui qui fait tourner ton main).

    Et oui, c'est à faire avant d'appeler le initialcontext.

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