遍历文件系统时克服权限错误

时间:2015-07-27 22:00:19

标签: recursion vbscript permissions filesystems file-permissions

我正在构建一个VBScript来搜索和记录从主目录中复制的文件的位置(重复)。

我目前有一个脚本递归搜索C盘并将所有文件位置记录到日志文件中。 (这不优雅,但我仍在研究概念证明。)

然而,当我遍历文件系统时,我发现脚本甚至无法查看很多文件夹 - Appdata,本地设置,我的视频,我的图片等。

因此用户显然无法访问这些内容,但用户对“我的文档”中的文件夹拥有所有权,因此我无法确定为什么我的脚本甚至无法读取其内容。用户是本地管理员。

我尝试通过将此代码段添加到开头而不改变行为来尝试使用提升的权限运行脚本:

If Not WScript.Arguments.Named.Exists("elevate") Then
    CreateObject("Shell.Application").ShellExecute WScript.FullName _
    , WScript.ScriptFullName & " /elevate", "", "runas", 1
    WScript.Quit
End If

这是脚本中的一个显着功能,错误输出的行(请告诉我其他部分是否有帮助):

' Get list of ALL files recursively and record them in a text file
Function getAllFilesRecursively (specifiedFolder, logLocation)

    If (Right(specifiedFolder,7)<>"AppData") And _
       (Right(specifiedFolder,16)<>"Application Data") And _
       (Right(specifiedFolder,7)<>"Cookies") And _
       (Right(specifiedFolder,14)<>"Local Settings") Then

        ' Get list of files in current folder
        Set objFSO = CreateObject("Scripting.FileSystemObject")
        Set objFolder = objFSO.GetFolder(specifiedFolder.Path)
        Set colFiles = objFolder.Files

        'This function writes to a specified log file, using the specified method
        writeToFile specifiedFolder, logLocationTemp, "Append" 

        ' For each file, perform a task 
        For Each objFile in colFiles '(<<<<<<<<<<<<<<<<<<<< permissions error)
            ' Compose the full path to the file
            fullPath = specifiedFolder & "\" & objFile.name

            'Save the path to a text file (a newline is automatically added)
            writeToFile fullPath, logLocation, "Append"
        Next

        ' For each folder, Recurse
        For Each Subfolder in specifiedFolder.SubFolders
            getAllFilesRecursively Subfolder, logLocation
        Next
    End If
End Function

我有什么方法可以让这个脚本访问这些文件夹吗?计算机在域上,但我可以进行必要的修改(甚至是策略)。

1 个答案:

答案 0 :(得分:1)

提供错误的文件夹可能不是实际文件夹,而是文件夹的符号链接。它们出于兼容性原因而存在,并且有一个ACE“每个人拒绝列表文件夹,仅此文件夹”,以防止人们浏览。不要乱动他们。制作排除列表以防止脚本尝试遍历它们。

Set exclude = CreateObject("Scripting.Dictionary")
exclude.CompareMode = vbTextCompare
exclude.Add "Application Data", True
exclude.Add "Local Settings", True
...

Function getAllFilesRecursively (specifiedFolder, logLocation)
    ...
    For Each Subfolder in specifiedFolder.SubFolders
        If Not exclude.Exists(Subfolder.Name) Then
            getAllFilesRecursively Subfolder, logLocation
        End If
    Next
End Function