Network share : connexion a un partage reseau avec authentification

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 / Exemple :


[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

Codes Sources

A voir également

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.