Accueil > > > REMPLACEMENT DE LA COMMANDE NET USE POUR CONNECTER ET DÉCONNECTER UN LECTEUR RÉSEAU
REMPLACEMENT DE LA COMMANDE NET USE POUR CONNECTER ET DÉCONNECTER UN LECTEUR RÉSEAU
Information sur la source
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.
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko [FRAMEWORK 4] LES TASKS ET LE THREAD UI[FRAMEWORK 4] LES TASKS ET LE THREAD UI par fathi
Je viens de passer quelques temps au TechDay's et j'ai pu voir pas mal de session intéressante. Par contre une chose m'a un peu étonné lors de certaines de ces sessions qui abordaient les améliorations du framework .NET (donc le 4.5) : en gros, bea...
Cliquez pour lire la suite de l'article par fathi WORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBEWORKFLOW FOUNDATION 3 A UN PIED DANS LA TOMBE par JeremyJeanson
Depuis déjà un an, je conseille vivement les utilisateurs de Workflow Foundation 3 à migrer vers la version 4. L'information qui va suivre ne devrait donc pas trop prendre au dépourvu les personnes qui m'ont suivi. Je profite de ce poste, pour faire le re...
Cliquez pour lire la suite de l'article par JeremyJeanson TECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PCTECHDAYS PARIS 2012 : NOUVELLES TENDANCES DU POSTE DE TRAVAIL - BRING YOUR OWN PC par ROMELARD Fabrice
Speakers: Thierry Rapatout, Antoine Petit et Xavier Trebbia Cette session entre dans le cadre des RDV Décideurs des TechDays 2012, elle est liée à la consumérisation de l'IT et la mise en place du "DeskTop as a Service" dans de plus en ...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|