我的 VBScript 中有一个要求,以确保驱动器已映射且可联系。
最初我只使用 的DriveExists()
方法FileSystemObject
,但在某些情况下,用户在办公室开始新的一天,然后带着他们的笔记本电脑去旅行,而没有关机,因此效果不佳;因此,有问题的驱动器仍列为已映射,但不可联系。
为了解决这个问题,我创建了以下函数,但由于使用On Error Resume Next
.
所以我的问题是这样的;是否有一种方法可以实现我在 VBS 中内置的目标,或者我的方法(或类似方法)是唯一可以完成的方法?
Function CheckDriveExists(drive)
CheckDriveExists = false
If FSO.DriveExists(drive) Then ' A drive is mapped for the required 'drive'
'** Create a file name for the test file *'
Dim tfDate, tfName
tfDate = Year(Now) & Month(Now) & Day(Now) & Hour(Now) & Minute(Now) & Second(Now)
tfName = "tstfile-" & tfDate & ".bucf"
'** Try to create and then delete a file on the usrs backup drive *'
On Error Resume Next
FSO.CreateTextFile(drive & ":\" & tfName)
FSO.DeleteFile(drive & ":\" & tfName)
CheckDriveExists = (Err.Number = 0) ' Check to see if the file was created and deleted successfully
Err.Clear ' Clear any possible error
On Error GoTo 0 ' Reset error handling
End If
End Function