Soyez le premier à donner votre avis sur cette source.
Snippet vu 23 551 fois - Téléchargée 35 fois
Option Explicit Declare Function WNetAddConnection2 Lib "mpr.dll" Alias _ "WNetAddConnection2A" (lpNetResource As NETRESOURCE, _ ByVal lpPassword As String, ByVal lpUserName As String, _ ByVal dwFlags As Long) As Long Declare Function WNetCancelConnection2 Lib "mpr.dll" Alias _ "WNetCancelConnection2A" (ByVal lpName As String, _ ByVal dwFlags As Long, ByVal fForce As Long) As Long Type NETRESOURCE dwScope As Long dwType As Long dwDisplayType As Long dwUsage As Long lpLocalName As String lpRemoteName As String lpComment As String lpProvider As String End Type Public Const NO_ERROR = 0 Public Const CONNECT_UPDATE_PROFILE = &H1 ' The following includes all the constants defined for NETRESOURCE, ' not just the ones used in this example. Public Const RESOURCETYPE_DISK = &H1 Public Const RESOURCETYPE_PRINT = &H2 Public Const RESOURCETYPE_ANY = &H0 Public Const RESOURCE_CONNECTED = &H1 Public Const RESOURCE_REMEMBERED = &H3 Public Const RESOURCE_GLOBALNET = &H2 Public Const RESOURCEDISPLAYTYPE_DOMAIN = &H1 Public Const RESOURCEDISPLAYTYPE_GENERIC = &H0 Public Const RESOURCEDISPLAYTYPE_SERVER = &H2 Public Const RESOURCEDISPLAYTYPE_SHARE = &H3 Public Const RESOURCEUSAGE_CONNECTABLE = &H1 Public Const RESOURCEUSAGE_CONTAINER = &H2 ' Error Constants: Public Const ERROR_ACCESS_DENIED = 5& Public Const ERROR_ALREADY_ASSIGNED = 85& Public Const ERROR_BAD_DEV_TYPE = 66& Public Const ERROR_BAD_DEVICE = 1200& Public Const ERROR_BAD_NET_NAME = 67& Public Const ERROR_BAD_PROFILE = 1206& Public Const ERROR_BAD_PROVIDER = 1204& Public Const ERROR_BUSY = 170& Public Const ERROR_CANCELLED = 1223& Public Const ERROR_CANNOT_OPEN_PROFILE = 1205& Public Const ERROR_DEVICE_ALREADY_REMEMBERED = 1202& Public Const ERROR_EXTENDED_ERROR = 1208& Public Const ERROR_INVALID_PASSWORD = 86& Public Const ERROR_NO_NET_OR_BAD_PATH = 1203& Public Const ERROR_NOT_CONNECTED = 2250& Public inpara() As String Public Function GetCommandLine(Optional MaxArgs) ' Déclare les variables. Dim C, CmdLine, CmdLnLen, InArg, I, NumArgs ' Vérifie si MaxArgs a été spécifié. If IsMissing(MaxArgs) Then MaxArgs = 10 ' Définit un tableau au format approprié. ReDim inpara(MaxArgs) NumArgs = 0: InArg = False ' Récupère les arguments de ligne de commande. CmdLine = Command() CmdLnLen = Len(CmdLine) ' Analyse de la ligne de commande caractère par caractère. For I = 1 To CmdLnLen C = Mid(CmdLine, I, 1) ' Analyse de caractères d'espacement ou de tabulations. If (C <> " " And C <> vbTab) Then ' Ni espace ni tabulation. ' Vérifie une éventuelle présence dans l'argument. If Not InArg Then ' Le nouvel argument commence. ' Vérifie si les arguments ne sont pas trop nombreux. If NumArgs = MaxArgs Then Exit For NumArgs = NumArgs + 1 InArg = True End If ' Concatène un caractère à l'argument courant. inpara(NumArgs) = inpara(NumArgs) & C Else ' Recherche un espace ou une tabulation. ' L'indicateur InArg prend la valeur False. InArg = False End If Next I ' Redimensionne le tableau pour qu'il puisse ' juste contenir les arguments. ReDim Preserve inpara(NumArgs) ' Renvoie le tableau dans le nom de fonction. GetCommandLine = inpara() End Function Public Sub Main() ' Le programme Connect permet de connecter ou de déconnecter un lecteur réseau dans un script ' La syntaxe est : ' Pour connecter : connect ADD d: \\serveur\partage ID password ' Pour déconnecter : connect DELETE d: ' Le programme crée un fichier connect.log dans son répertoire ' En cas d'échec, il crée également un fichier connect.err dans son répertoire Dim NetR As NETRESOURCE Dim ErrInfo As Long Dim MyPass, MyUser As String Dim num As Integer Dim fs As FileSystemObject Dim a As TextStream Set fs = CreateObject("Scripting.FileSystemObject") App.StartLogging App.Path & "\connect.log", vbLogToFile NetR.dwScope = RESOURCE_GLOBALNET NetR.dwType = RESOURCETYPE_DISK NetR.dwDisplayType = RESOURCEDISPLAYTYPE_SHARE NetR.dwUsage = RESOURCEUSAGE_CONNECTABLE inpara = GetCommandLine If inpara(1) = "ADD" Then NetR.lpLocalName = inpara(2) NetR.lpRemoteName = inpara(3) MyUser = inpara(4) MyPass = inpara(5) ErrInfo = WNetAddConnection2(NetR, MyPass, MyUser, 0) If ErrInfo = NO_ERROR Then Debug.Print inpara(2) & " connecté sur " & inpara(3) App.LogEvent inpara(2) & " connecté sur " & inpara(3) If Dir(App.Path & "\connect.err") <> "" Then fs.DeleteFile App.Path & "\connect.err" Else ErrInfo = WNetCancelConnection2(NetR.lpLocalName, CONNECT_UPDATE_PROFILE, True) If ErrInfo = NO_ERROR Then Debug.Print inpara(2) & " déconnecté" App.LogEvent inpara(2) & " déconnecté" ErrInfo = WNetAddConnection2(NetR, MyPass, MyUser, 0) If Dir(App.Path & "\connect.err") <> "" Then fs.DeleteFile App.Path & "\connect.err" If ErrInfo = NO_ERROR Then Debug.Print inpara(2) & " connecté sur " & inpara(3) App.LogEvent inpara(2) & " connecté sur " & inpara(3) If Dir(App.Path & "\connect.err") <> "" Then fs.DeleteFile App.Path & "\connect.err" Else Debug.Print "ERREUR de connexion de " & inpara(2) & " sur " & inpara(3) App.LogEvent "ERREUR de connexion de " & inpara(2) & " sur " & inpara(3) Set a = fs.CreateTextFile(App.Path & "\connect.err", True) a.WriteLine "ERREUR de connexion de " & inpara(2) & " sur " & inpara(3) a.Close End If Else Debug.Print "ERREUR de connexion de " & inpara(2) & " sur " & inpara(3) App.LogEvent "ERREUR de connexion de " & inpara(2) & " sur " & inpara(3) Set a = fs.CreateTextFile(App.Path & "\connect.err", True) a.WriteLine "ERREUR de connexion de " & inpara(2) & " sur " & inpara(3) a.Close End If End If Else If inpara(1) = "DELETE" Then NetR.lpLocalName = inpara(2) ErrInfo = WNetCancelConnection2(NetR.lpLocalName, CONNECT_UPDATE_PROFILE, True) If ErrInfo = NO_ERROR Or ErrInfo = ERROR_NOT_CONNECTED Then Debug.Print inpara(2) & " déconnecté" App.LogEvent inpara(2) & " déconnecté" If Dir(App.Path & "\connect.err") <> "" Then fs.DeleteFile App.Path & "\connect.err" Else Debug.Print "ERREUR: " & ErrInfo & " - Erreur de déconnexion de " & inpara(2) App.LogEvent "ERREUR: " & ErrInfo & " - Erreur de déconnexion de " & inpara(2) Set a = fs.CreateTextFile(App.Path & "\connect.err", True) a.WriteLine "ERREUR de déconnexion de " & inpara(2) & " sur " & inpara(3) a.Close End If Else Debug.Print "ERREUR de commande" App.LogEvent "ERREUR de commande" Set a = fs.CreateTextFile(App.Path & "\connect.err", True) a.WriteLine "ERREUR de commande" a.Close End If End If Close num End Sub
6 janv. 2007 à 14:23
8 févr. 2006 à 12:13
Un brin compliqué au à comprendre (désolé je suis nouveau en VB) mais trés trés bien.
Merci beaucoup !!!
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.