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

Développement SQL Server Discussion :

Le fournisseur OLE DB "SQLNCLI11" du serveur lié "NomServ" a rapporté une erreur. Échec de l'authentification


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2013
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2013
    Messages : 24
    Par défaut Le fournisseur OLE DB "SQLNCLI11" du serveur lié "NomServ" a rapporté une erreur. Échec de l'authentification
    Bonjour,

    Sous MS SQLServer, je fais appelle une procédure qui accède à un serveur distant (NomServ)
    Cela marche très bien car j'ai vérifié que les 2 serveurs liés communiquent bien entre eux en appliquant les recommandations de Microsoft (https://msdn.microsoft.com/fr-fr/lib....aspx#Anchor_5)

    Ci-dessous l'appel à la procédure stockée
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    declare @P0 INTEGER
    EXEC pack_NomProcedure @P0 OUT,Param2, Param3
    où Param2 et Param3 sont valorisés


    Côté JAVA :
    Quand j'essaie d'appeler la même procédure stockée, j'ai le message suivant :
    [quote"]com.microsoft.sqlserver.jdbc.SQLServerException, message = Le fournisseur OLE DB "SQLNCLI11" du serveur lié "NomServ" a rapporté une erreur. Échec de l'authentification.[/quote]


    Ci-dessous, l'appel à la procédure stockée

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    DBTransaction	 trans = (DBTransaction)appModule.getTransaction();
    CallableStatement callStmt = null;
     
    callStmt = trans.createCallableStatement( "EXEC pack_NomProcedure ?,?,?", DBTransaction.DEFAULT );
     
    callStmt.registerOutParameter( 1, Types.INTEGER );
    callStmt.setInt( 2, Param2 );
    callStmt.setString( 3, Param3 );
     
    callStmt.execute();
    Merci pour votre aide

  2. #2
    Invité
    Invité(e)
    Par défaut
    Ton linked server gère comment les connexions ? Quel est l'utilisateur dans la base cible lorsque tu te connectes à java ?

  3. #3
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2013
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2013
    Messages : 24
    Par défaut
    Concernant le linked server cible:
    Clic droit + propriété sur le serveur lié
    Onglet général : Type de serveur : SQL Server
    Onglet option du serveur cible : cf option du serveur.png
    Propiété de connexion du serveru cible: propiété de connexion.png

    L'utilisateur de base cible est 'sa'
    Images attachées Images attachées   

  4. #4
    Membre averti
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2013
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2013
    Messages : 24
    Par défaut
    C'est bon j'ai trouvé d'où venait le problème
    Côté Java, je me connecte avec NomBaseSource/mdpBaseSource pour attaquer la base cible (NomBaseCible/mdpBaseCible)
    Dans la propiété du serveur lié, il faut définir la connexion suivante :

    Connexion_locale Utilisateur_distant Mot_de_passe_distant
    ---------------- ----------------- ----------------------
    NomBaseSource NomBaseCible mdpBaseCible

  5. #5
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Connexion sous le compte sa, qui est membre du rôle de serveur sysadmin qui dispose de tous les droits sur une instance, c'est quand même très moche et aussi très connu ...

    @++

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

Discussions similaires

  1. [ ADO ] Tracer le fournisseur OLE DB
    Par pascal07 dans le forum Bases de données
    Réponses: 15
    Dernier message: 21/09/2009, 09h52
  2. fournisseur OLE DB
    Par tjotreau dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 06/06/2007, 14h25

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