Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

NETWORK SHARE : CONNEXION A UN PARTAGE RESEAU AVEC AUTHENTIFICATION


Information sur la source

Catégorie :Réseaux & Internet Source .NET ( DotNet ) Classé sous : partage, authentification, wnetaddconnection3, netresource Niveau : Débutant Date de création : 29/11/2005 Date de mise à jour : 04/05/2008 17:47:33 Vu / téléchargé: 17 438 / 1 122

Note :
9,6 / 10 - par 5 personnes
9,60 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (4)
Ajouter un commentaire et/ou une note


Description

Une petite classe utilitaire utilisant l'API WNetAddConnection3 afin de procéder à l'authentification de l'utilisateur. (Un peu (beaucoup) similaire à l'utilisation de la commande net use.)
La classe utilitaire étant ici limitée à la connexion à un partage de fichiers, sans gérer la persistence de la connexion établie entre les sessions.
Mais il suffit de le rajouter ;-)

La connexion peut se faire soit avec les noms et pass de l'utilisateur courant, soit en les spécifiant.
L'affichage (ou non) de l'invite de saisie à l'utilisateur (celle que l'ont rencontre lors de l'accès par explorer) peut être demandée de manière optionnelle (voir enumeration PromptMode) :
- si nécessaire : l'invite ne s'affiche que si les paramètres précédants ne permettent pas de se connecter au partage)
- toujours : l'invite s'affiche directement
Il est possible de la rendre modale par rapport à l'application en passant le handle de fenêtre.

WNetCancelConnection2 est utilisée de supprimer immédiatement la connexion crée.

WNetAddConnection3 est privilégiée par rapport à WNetAddConnection2 pour l'utilisation du handle de fenêtre.

 

Source

  • [DllImport("mpr.dll")]
  • public static extern uint WNetAddConnection3(
  • [In]IntPtr hwndOwner,
  • [In]ref NETRESOURCE lpNetResource,
  • [In]string lpPassword,
  • [In]string lpUsername,
  • [In]WNetAddConnectionFlags dwFlags
  • );
  • [DllImport("mpr.dll")]
  • public static extern uint WNetCancelConnection2(
  • [In]string lpName,
  • [In]WNetCancelConnectionFlags dwFlags,
  • [In]bool fForce
  • );
  • // les méthodes de connexion disponibles
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, PromptMode mode);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, IntPtr hwndOwner);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, PromptMode mode, IntPtr hwndOwner);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass, PromptMode mode);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass, IntPtr hwndOwner);
  • public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass, PromptMode mode, IntPtr hwndOwner);
  • // la méthode qui effectue l'appel de WNetAddConnection3
  • private static NetworkShare ConnectDiskInternal(string remoteName, string user, string pass, NativeMethods.WNetAddConnectionFlags flags, IntPtr hwndOwner)
  • {
  • NetworkShare share = null;
  • try
  • {
  • uint ret;
  • NETRESOURCE netres = new NETRESOURCE();
  • netres.dwType = NETRESOURCE.Type.RESOURCETYPE_DISK;
  • netres.lpRemoteName = remoteName;
  • ret = NativeMethods.WNetAddConnection3(
  • hwndOwner,
  • ref netres,
  • pass,
  • user,
  • flags
  • );
  • if ( ret == NativeMethods.NO_ERROR )
  • {
  • share = new NetworkShare(remoteName);
  • }
  • else
  • {
  • share = null;
  • }
  • }
  • catch
  • {
  • share = null;
  • }
  • return share;
  • }
[DllImport("mpr.dll")]
public static extern uint WNetAddConnection3(
    [In]IntPtr hwndOwner, 
    [In]ref NETRESOURCE lpNetResource, 
    [In]string lpPassword, 
    [In]string lpUsername, 
    [In]WNetAddConnectionFlags dwFlags 
    );


[DllImport("mpr.dll")]
public static extern uint WNetCancelConnection2(
    [In]string lpName, 
    [In]WNetCancelConnectionFlags dwFlags, 
    [In]bool fForce
    );


// les méthodes de connexion disponibles
public static NetworkShare.NetworkShare ConnectDisk(string remoteName);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, PromptMode mode);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, IntPtr hwndOwner);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, PromptMode mode, IntPtr hwndOwner);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass, PromptMode mode);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass, IntPtr hwndOwner);
public static NetworkShare.NetworkShare ConnectDisk(string remoteName, string user, string pass, PromptMode mode, IntPtr hwndOwner);

// la méthode qui effectue l'appel de WNetAddConnection3
private static NetworkShare ConnectDiskInternal(string remoteName, string user, string pass, NativeMethods.WNetAddConnectionFlags flags, IntPtr hwndOwner)
{
    NetworkShare share = null;

    try
    {
        uint ret;
        NETRESOURCE netres = new NETRESOURCE();
        netres.dwType = NETRESOURCE.Type.RESOURCETYPE_DISK;
        netres.lpRemoteName = remoteName;
    
        ret = NativeMethods.WNetAddConnection3(
            hwndOwner, 
            ref netres, 
            pass, 
            user, 
            flags
            );
    
        if ( ret == NativeMethods.NO_ERROR )
        {
            share = new NetworkShare(remoteName);
        }
        else
        {
            share = null;
        }
    }
    catch
    {
        share = null;
    }

    return share;
}

Conclusion

Les petits liens qui vont bien :

WNetAddConnection3 : http://msdn.microsoft.com/en-us/library/aa385418.aspx
WNetCancelConnection2 : http://msdn.microsoft.com/en-us/library/aa385427.aspx
NETRESOURCE : http://msdn.microsoft.com/en-us/library/aa385353.aspx
 

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Historique

04 mai 2008 17:47:33 :
Changement liens vers MSDN suite au shutdown complet de l'ancienne version (et des redirections).

Commentaires et avis

signaler à un administrateur
Commentaire de MorpionMx le 30/11/2005 09:42:27 administrateur CS

C'est bon a connaitre ca :)

signaler à un administrateur
Commentaire de yust le 08/02/2006 14:19:55

Bonjour,

Merci beaucoup pour ce code. C'est tout à fait ce que je cherchais...un moyen d'accéder à un share avec un utilisateur générique...

Je l'ai mis dans ma boite à outils...

Bon continuation et encore merci,

Yust.

signaler à un administrateur
Commentaire de coq le 08/02/2006 14:39:05 administrateur CS

Content que ça serve :-)

signaler à un administrateur
Commentaire de poirievincent le 04/12/2008 16:52:42 10/10

Vraiment géniale ton code est vraiment utile.
merci

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

Fichiers en partage [ par SebSharp ] Salut à tous, J'aimerais savoir s'il y a moyen de partagé une classe( un simple fichier .cs) dans plusieurs projets sans que celle-ci soit recopié dan authentification utilisateur base de données Access en c# [ par liliemumue ] BonjourJe ne connais rien au base de données et la j'avoue que je n'y arrive pas.Deja en premier lieu j'ai cree une base access avec plusieurs tables, authentification LDAP en c# et ASP.NET [ par crapulas ] Bonjour, j'ai créé une page de connexion pour un site web evec des textbox, label etc... en ASP.NET et avec du c#Il est demandé à la personne de rentr Accéder à un partage administratif en C# [ par azgar ] Salut, Je souhaite accéder à un partage administartif d'un ordinateur sur le réso.Mais je ne trouve rien pour lui spécifier le mot de pass ... et en g Treeview : erreur de lecture du fichier XML en authentification intégrée [ par Drix78 ] Bonjour,après avoir tenté d'exécuter un sample tout bête du webcontrol treeview, avec un fichier XML, je me suis rendu compte qu'il m'était impossible Partage d'un fichier documentation entre plusieurs projets d'une même solution [ par staik ] Bonjour,Ma solution contient autant de projets que de niveaux applicatifs (framework, businessrules, web).Chaque classe et ses membres sont est b Authentification en C# [ par sab741 ] Bonjour,J'ai créé un formulaire avec un login et mot de passe ainsi qu'un bouton Login ( tout simple)!Or tous mes clients ne sont pas dans u INSTALLER APPLICATION WINDOWS FORM C# EN PARTAGE [ par pf2711 ] Bonjour à tous, j'aimerais installer une application windows c# en partage sur un serveur. Comme je n'ai pas trop de notions dans ce domaine, j Authentification via dba_users d'oracle [ par winz611 ] Bonjour, Je voudrais authentifier les utilisateurs d'une appli asp.net en interrogant la table dab_users d'une base oracle. Les mots de passe sont cry Se Connecter à un partage de fichiers: TcpClient, TcpListener, NetworkStream [ par saadaouimouad ] Bonjour, Dans un partage de fichiers je dois écouter scruter les messages texte reçus dans une machine hôte pour les stocker dans des tables SQL Serve


Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,452 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.