3

在 powershell 中存在一些我无法捕获的异常,或者我没有采取任何措施来纠正问题。

所以这里是做这些事情的代码:

log "Processing $($_.Name).old" $logFile
if (Test-Path "$($_.Name).old" )
{
    & { 
        rm "$($_.Name).old" 
    }
    trap #[System.UnauthorizedAccessException]
    {
        log "Move to trash" $logFile
        moveTrach "$($_.Name).old" 
        continue
    }
}

我已经注释掉了陷阱表达式中的类型,以确保捕捉到任何东西。但不幸的是,我从来没有进入陷阱条款。

我可以看到异常日志,但看不到“移至垃圾箱”日志。

2012-02-16 10:35:31 Processing file.dll
Remove-Item : Cannot remove item file.dll.old: Access to the path 'file.dll.old' is     denied.
At upgradegw.ps1:189 char:29
+                         rm <<<<  "$($_.Name).old" 
+ CategoryInfo          : PermissionDenied: (file.dll.old:FileInfo) [Remove-Item], UnauthorizedAccessException
+ FullyQualifiedErrorId : RemoveFileSystemItemUnAuthorizedAccess,Microsoft.PowerShell.Commands.RemoveItemCommand
2012-02-16 10:35:31 Processing file2.dll
4

1 回答 1

2

陷阱只会在终止错误时触发。

  rm "$($_.Name).old" -ErrorAction "Stop" 
于 2012-02-16T11:07:38.220 回答