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

Windows Discussion :

[C] Récupérer les noms de domaines


Sujet :

Windows

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 43
    Points : 26
    Points
    26
    Par défaut [C] Récupérer les noms de domaines
    Bonjour à tous,

    voilà mon problème, je souhaite lancer un programme avec un autre utilisateur que l'utilisateur courant. Pour cela, j'ai vu qu'il faut utiliser LogonUser, puis toute une suite de commandes... Or je bloque déjà au niveau de LogonUser.

    J'ai fait une petite interface dans laquelle on rentre login, mot de passe et on choisit le domaine dans un combobox. Pour remplir le combobox, j'utilisais jusque là la sortie d'un "net view /domain" mais je me suis rendu compte que ca posait problème... net view ne me donne pas le nom complet du domaine. Par exemple, pour toto.net, il me donne toto. Du coup, quand je fais l'appel à LogonUser, ca ne fonctionne pas (mot de passe ou nom d'utilisateur incorrect). J'ai essayé l'appel à LogonUser en mettant toto.net comme nom de domaine, et là, ca fonctionne.

    La question est : comment faire pour récupérer les noms complets comme quand on ouvre une session windows ?

    Et puis par la meme occasion, comment je peux récupérer les noms des postes situés sur le domaine sélectionné par l'utilisateur (pour le moment, je fais un net view /domain:domain_name) ?

    Merci d'avance pour votre aide...

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Avec LogonUser, tu ne pourras pas créer de processus avec un autre nom d'utilisateur si tu n'es pas un service: Cela nécessite un privilège que seul NT AUTHORITY\LocalSystem possède.

    Pour créer un processus avec un autre nom d'utilisateur, il te faudra utiliser CreateProcessWithLogonW().
    PS: Pour l'ordinateur local, tu peux toujours mettre NULL comme nom de domaine.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 43
    Points : 26
    Points
    26
    Par défaut
    Alors autre question, si je fais sans le CreateProcessWithLogonW() et que quand le user se connecte, j'ouvre une boite dialog après avoir fait le LogonUser et le ImpersonateLoggedOnUser(), c'est pas suffisant ?

    Enfin, je peux utiliser CreateProcessWithLogonW(), ce n'est pas genant mais c'est juste pour savoir...

    Et au niveau des différents noms de domaines ? Pour le poste local, je sais que je peux mettre NULL, mais le but, c'est de se connecter aux différents domaines pour pouvoir déployer un service..

    Merci pour votre aide

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Pour LogonUser() et ImpersonateLoggedOnUser() (qui ne marche que si on a le privilège "Impersonate" que possèdent les admins), tout doit marcher tant que tu ne crées pas de nouveau processus. (enfin, je pense).
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 43
    Points : 26
    Points
    26
    Par défaut
    Ok, quand je peux je fais un test et je vous redis

    Par contre, si quelqu'un a une idée pour les noms de domaines... Je fouille dans la msdn là mais je trouve pas grand chose

  6. #6
    Expert éminent sénior

    Homme Profil pro
    pdg
    Inscrit en
    Juin 2003
    Messages
    5 751
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : pdg

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 751
    Points : 10 670
    Points
    10 670
    Billets dans le blog
    3
    Par défaut
    J'ai du mal à comprendre. Il me semble que Net View te liste des ordis, je vois pas trop le rapport avec ce que tu veux faire, ni vraiment même ce que tu veux faire.

    Citation Envoyé par Médinoc
    Avec LogonUser, tu ne pourras pas créer de processus avec un autre nom d'utilisateur si tu n'es pas un service: Cela nécessite un privilège que seul NT AUTHORITY\LocalSystem possède.

    Pour créer un processus avec un autre nom d'utilisateur, il te faudra utiliser CreateProcessWithLogonW().
    Tu es sûr ? La doc de CreateProcessWithLogonW dit que ça revient à combiner LogonUser + CreateProcessAsUser.
    http://msdn.microsoft.com/library/en-us/secauthz/security/starting_an_interactive_client_process_in_c__.asp

  7. #7
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 43
    Points : 26
    Points
    26
    Par défaut
    Citation Envoyé par Aurelien.Regat-Barrel
    J'ai du mal à comprendre. Il me semble que Net View te liste des ordis, je vois pas trop le rapport avec ce que tu veux faire, ni vraiment même ce que tu veux faire
    renvoie la liste des domaines

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    net view /domain:domain_name
    renvoie la liste des ordinateurs connectés au domaine domain_name.

    Or, net view /domain me renvoie toto et dans le LogonUser, il me faudrait toto.net.

    Je fais ça pour pouvoir, à partir d'un seul poste, me connecter en adimn de chacun des domaines disponibles et déployer un service...

    Merci d'avance[/code]

  8. #8
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Citation Envoyé par Aurelien.Regat-Barrel
    Tu es sûr ? La doc de CreateProcessWithLogonW dit que ça revient à combiner LogonUser + CreateProcessAsUser.
    À cette différence près:
    Citation Envoyé par La page en question
    Note that your process must have the SE_ASSIGNPRIMARYTOKEN_NAME and SE_INCREASE_QUOTA_NAME privileges for successful execution of CreateProcessAsUser
    CreateProcessWithLogonW() ne nécessite pas ce privilège (oui je suis sûr, j'ai essayé les deux, et seul CreateProcessWithLogonW() a marché).

    Sinon, il semblerait que CreateProcessWithTokenW() n'ait pas non plus besoin de privilège, mais il exige Windows Vista...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  9. #9
    Expert éminent sénior

    Homme Profil pro
    pdg
    Inscrit en
    Juin 2003
    Messages
    5 751
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : pdg

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 751
    Points : 10 670
    Points
    10 670
    Billets dans le blog
    3
    Par défaut
    Essaye NetGetJoinInformation. TranslateName peut aussi être utile.

    Citation Envoyé par Médinoc
    Citation Envoyé par Aurelien.Regat-Barrel
    Tu es sûr ? La doc de CreateProcessWithLogonW dit que ça revient à combiner LogonUser + CreateProcessAsUser.
    À cette différence près:
    Citation Envoyé par La page en question
    Note that your process must have the SE_ASSIGNPRIMARYTOKEN_NAME and SE_INCREASE_QUOTA_NAME privileges for successful execution of CreateProcessAsUser
    CreateProcessWithLogonW() ne nécessite pas ce privilège (oui je suis sûr, j'ai essayé les deux, et seul CreateProcessWithLogonW() a marché).
    Ce n'est pas parce que tu n'as pas le privilège que tu ne peux pas le demander. C'est ce qui est fait il me semble dans le lien que j'ai donné.
    C'est comme pour arrêter Windows NT. Un simple appel à ExitWindowsEx échoue même en admin, mais après t'être rajouté le privilège SeShutdownPrivilege, c'est bon.

    Enfin bon, dans ce cas précis j'ai pas testé. Mais ça serait bizarre quand même.

  10. #10
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Tu sais, j'ai déjà fait une fonction qui énumère les privilèges, pour découvrir qu'ils avaient trois états: Actif, inactif (doit être demandé), et inacessible (ne peut pas être demandé).

    LocalSystem est le seul pour lequel SE_ASSIGNPRIMARYTOKEN_NAME n'est pas en "inaccessible".
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  11. #11
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 43
    Points : 26
    Points
    26
    Par défaut
    Citation Envoyé par Aurelien.Regat-Barrel
    Essaye NetGetJoinInformation. TranslateName peut aussi être utile.
    NetGetJoinInformation : The NetGetJoinInformation function retrieves join status information for the specified computer

    TranslateName : The TranslateName function converts a directory service object name from one format to another

    J'ai pas l'impression que ca corresponde à ce dont j'ai besoin...

    En gros, il me faut un net view en plus complet, ou alors des fonctions qui me permettrait de coder ça...

  12. #12
    Expert éminent sénior

    Homme Profil pro
    pdg
    Inscrit en
    Juin 2003
    Messages
    5 751
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : pdg

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 751
    Points : 10 670
    Points
    10 670
    Billets dans le blog
    3
    Par défaut
    Ce que tu peux faire c'est énumérer toutes les ressources reseau et ainsi lister les domaines avec NetUseEnum / WNetEnumResource.
    Mais je suis aussi tombé sur ça:
    DsEnumerateDomainTrusts, IDsBrowseDomainTree, ...
    http://msdn.microsoft.com/library/en-us/ad/ad/active_directory.asp
    mais c'est lié à l'AD, et j'ai jamais testé.

  13. #13
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 43
    Points : 26
    Points
    26
    Par défaut [C] Récupérer les noms de domaines
    Je te remercie. J'ai pas pris le temps de regarder tes fonctions mais j'ai trouvé une solution à mon problème. Avec mon programme, je fournirais les libs d'OpenLDAP, et puis je ferais des recherches sur le controleur de domaine. C'et moins pratique pour récupérer la sortie, mais il me fallait une solution rapidement!

    Encore merci

Discussions similaires

  1. Récupérer tous les noms de domaine d'un champ adresse mail
    Par Elwood J. Blues dans le forum Requêtes
    Réponses: 2
    Dernier message: 17/08/2011, 15h04
  2. Les noms de domaines disponible
    Par rabobsky dans le forum Domaines
    Réponses: 4
    Dernier message: 19/02/2006, 23h46
  3. ShellListView : comment récupérer les noms des fichiers?
    Par Lolo1988 dans le forum Composants VCL
    Réponses: 1
    Dernier message: 11/12/2005, 23h19
  4. Réponses: 2
    Dernier message: 03/02/2005, 13h21
  5. Récupérer le nom de domaine d'appartenance d'un serveur
    Par Laurent Dardenne dans le forum Windows
    Réponses: 2
    Dernier message: 26/01/2004, 17h01

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