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 !

REMPLACEMENT DE LA COMMANDE NET USE POUR CONNECTER ET DÉCONNECTER UN LECTEUR RÉSEAU


Information sur la source

Catégorie :Réseau & Internet Niveau : Débutant Date de création : 19/10/2004 Date de mise à jour : 19/10/2004 17:36:51 Vu : 15 500

Note :
7,67 / 10 - par 3 personnes
7,67 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

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

Description

La commande net use sous Windows 2000, 2003, XP, ... permet de connecter et de déconnecter un lecteur réseau mais elle ne se termine pas toujours automatiquement en cas d'erreur et le script qui l'emploie se bloque alors. Mon programme, CONNECT, permet de connecter un lecteur réseau avec la syntaxe CONNECT ADD x: \\serveur\partage ID Password, ou de déconnecter un lecteur réseau avec le syntaxe CONNECT DELETE x:.
En cas d'erreur, un fichier connect.err est créé dans le répertoire, ce qui permet l'usage de la commande IF EXIST pour aiguiller correctement un script. Dans tous les cas un fichier connect.log enregistre l'opération réalisée. Si x: est déja connecté, le programme le déconnecte puis le reconnecte. Ceci est enregistré dans le log.
 

Source

  • 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
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

Conclusion

Ce programme n'a pas de fenêtre de commande. Il est défini comme un projet autonome.
Les lignes Debug.Print n'ont pas d'utilité particulière, sinon pour la mise au point du programme. Elles peuvent être supprimées sans problème.
 

Historique

19 octobre 2004 17:36:51 :
Ajout d'un commentaire.

Commentaires et avis

signaler à un administrateur
Commentaire de zebecasse le 08/02/2006 12:13:45

Parfait !

Un brin compliqué au à comprendre (désolé je suis nouveau en VB) mais trés trés bien.

Merci beaucoup !!!

signaler à un administrateur
Commentaire de Shendoo le 06/01/2007 14:23:30

c'est tres bien mais un zippppppp    !!!!!!!!!!!!!!!!!!

Ajouter un commentaire



Nos sponsors

Sondage...

CalendriCode

Septembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
2930     

Consulter la suite du CalendriCode



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,13 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é.