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

ASP.NET Discussion :

Connexion à sql serveur via asp.net en sécurité intégré


Sujet :

ASP.NET

  1. #1
    Futur Membre du Club
    Inscrit en
    Février 2009
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 9
    Points : 5
    Points
    5
    Par défaut Connexion à sql serveur via asp.net en sécurité intégré
    Bonjour à tous,

    Je crée une application intranet accessible par un utilisateur que l'on appelera Bob.

    Bob a un compte sur windows ainsi qu'un compte sur sqlserveur avec des droits qui lui sont associés.

    Le but du jeu est qu'il se connecte sur une application asp.net et que celle ci se connecte avec son compte windows (celui de bob) à sql server.

    En conséquence, ma connectionstring est la suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Server=MonServeur; Database=MaDatabase; Integrated Security=SSPI;"
    Par ailleurs, j'ai ajouté dans mon web.config :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    <authentication mode="Windows"/>
        <identity impersonate="true"/>
    Le problème, c'est que mon appli ne se logue pas avec le compte de Bob et l'erreur suivante survient :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Échec de l'ouverture de session de l'utilisateur 'AUTORITE NT\ANONYMOUS LOGON'
    Je me suis inspiré des articles suivants pour trouver une solution :
    Unable to use Kerberos Delegation from IE6 --> IIS 5.0
    How To: Connect to SQL Server Using Windows Authentication in ASP.NET 2.0

    mais sans succes...

    Si quelqu'un à déjà réussi se genre de chose...

    J'ai essayé la delegation Kerberos en autorisant sqlserveur et iis, mais j'ai toujours la même erreur

    En vous remerciant par avance

  2. #2
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2004
    Messages : 231
    Points : 165
    Points
    165
    Par défaut
    Essaye Integrated Security=true dans ta connnectionstring

  3. #3
    Futur Membre du Club
    Inscrit en
    Février 2009
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    nop, ca ne marche pas mieux

    Merci de ta réponse en tout cas

  4. #4
    Membre expérimenté Avatar de Arthis
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    1 265
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : Italie

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 265
    Points : 1 352
    Points
    1 352
    Par défaut
    sinon pense aussi a verifier l onglet securite de ton site web sous IIS, decoche anonymous et coche integrated authentication.

  5. #5
    Futur Membre du Club
    Inscrit en
    Février 2009
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Oui, j'ai déjà fait ca.

    J'ai oublié de le mentionner désolé

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2004
    Messages : 231
    Points : 165
    Points
    165
    Par défaut
    Essaye juste de retirer : <identity impersonate="true"/>

  7. #7
    Futur Membre du Club
    Inscrit en
    Février 2009
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    J'ai essayé, mais j'en ai besoin de toute manière pour récupérer le login windows de l'utilisateur avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WindowsIdentity.GetCurrent().Name
    Sans Impersonation, il me retourne l'utilisateur de la machine quelque soit l'utilisateur connecté.

    Mais globalement, si j'ai bien compris, l'impersonation sert justement à faire ce bon j'ai besoin :

    Pour emprunter l'identité d'un utilisateur d'authentification Microsoft Internet Information Services (IIS) pour chaque demande de page dans une application ASP.NET, vous devez insérer la balise <identity> dans le fichier Web.config de cette application et attribuer à l'attribut impersonate la valeur true

  8. #8
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    231
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juillet 2004
    Messages : 231
    Points : 165
    Points
    165
    Par défaut
    Moi j'utilises HttpContext.Current.User.Identity.Name pour récupérer le login NT du user connecté et j'ai la valeur de Impersonate par défaut (soit false).

    A confirmer, mais il me semble que ce impersonate à false utilise un utilisateur par défaut (NetworkService) pour executer le code ainsi que les appels à la base de données. Qui est a différencier du user dans l'application.

  9. #9
    Futur Membre du Club
    Inscrit en
    Février 2009
    Messages
    9
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 9
    Points : 5
    Points
    5
    Par défaut
    Oui, c'est vrai, tu as raison HttpContext.Current.User.Identity.Name permet bien de récupérer le nom du user.

    Ceci dit, avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <identity impersonate="false"/>
    dans le web.config, l'erreur que j'ai mis dans mon premier post :

    Échec de l'ouverture de session de l'utilisateur 'AUTORITE NT\ANONYMOUS LOGON'
    se transforme en :

    Échec de l'ouverture de session de l'utilisateur 'MON_DOMAINE\MON-IIS$'
    autrement dit, il essaye de se connecter avec les identifiants du serveur et pas avec ceux de l'utilisateur

Discussions similaires

  1. [SQL Server 2008 & ASP.NET] Connexion impossible à la base de données
    Par stringman62 dans le forum Accès aux données
    Réponses: 0
    Dernier message: 22/04/2010, 14h38
  2. Aide pour une connexion à sql serveur 2005 via Delphi 7
    Par fabpan dans le forum Bases de données
    Réponses: 2
    Dernier message: 10/11/2009, 20h52
  3. Aide pour une connexion à sql serveur 2005 via Delphi 7
    Par fabpan dans le forum Développement
    Réponses: 0
    Dernier message: 10/11/2009, 15h56
  4. [SQL-Server] Connexion à une table sous SQL Serveur Via PHP
    Par Phpdebut dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 07/01/2009, 16h03
  5. Connexion à SQL SERVEUR via VPN
    Par freud dans le forum Bases de données
    Réponses: 6
    Dernier message: 29/09/2007, 12h23

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