删除项目与 [System.IO.File]::Delete()

Remove-Item Vs [System.IO.File]::Delete()

我在 Azure Runbook 中有以下代码:

$pathToDownloadedBlob = 'C:\depId-20150904032522\SevenZipSharp.dll'
if ((Test-Path $pathToDownloadedBlob) -eq $true)
{
    try
    {
        Remove-Item -Path $pathToDownloadedBlob

    }
    catch
    {
        write-error "Could not delete $pathToDownloadedBlob. - $($error[0])"
        exit
    }
}

当我使用 Remove-Item 时出现此错误:

4/7/2015 2:14:14 PM, Error: Remove-Item : The converted JSON string is in bad format.
At DavidTest:45 char:45
+ 
    + CategoryInfo          : InvalidOperation: (System.Unauthor... Boolean force):ErrorRecord) [Remove-Item], 
InvalidOperationException
    + FullyQualifiedErrorId : JsonStringInBadFormat,Microsoft.PowerShell.Commands.RemoveItemCommand

当我改用 [System.IO.File]::Delete($using:path) 时,出现此错误:

4/7/2015 2:22:48 PM, Error: Exception calling "Delete" with "1" argument(s): "Access to the path 'C:\Deployment\SevenZipSharp.dll' is denied."
At DavidTest:46 char:46
+ 
    + CategoryInfo          : NotSpecified: (:) [], MethodInvocationException
    + FullyQualifiedErrorId : UnauthorizedAccessException

我知道我没有删除该文件的权限。 但是,为什么当我使用 Remove-Item 时它会抱怨 JSON 字符串?

编辑: 请注意,这仅发生在 Azure 自动化中。但是我无法在本地的 Powershell ISE 中真正复制它,因为我有权删除我想删除的文件。


更新:我刚刚意识到这只发生在 .dll 文件上。如果我尝试删除 .7z 文件,它工作正常。

我想这是由于在 PowerShell 工作流上下文和 InlineScript 工作流之间传递的对象的序列化/反序列化 Activity,它默认在单独的进程中运行。

您是总是传递 [System.String],还是有时传递 [System.IO.FileInfo] 对象?如果是后者,那么您可能希望引用 FullName 属性,而不是将对象本身传递给 Remove-Item.

我不是 100% 确定这就是您 运行 的目标,但值得讨论。

顺便说一下,作为最佳做法,请始终明确命名您的参数,以便其他人了解您在做什么。您对 Remove-Item 的调用不包括名称中的 -Path 参数,因为它的位置为 0。当然,当您寻求帮助时,认为这不是一件好事.最好详细一点。

希望这至少能有所帮助。顺便问一下,这个问题是 Azure Automation Runbook 独有的,还是在本地执行的 PowerShell 工作流中也存在?

编辑:这段代码在本地对我来说似乎工作得很好。

workflow test {
    $Path = 'C:\dsc\srv01.xml';
    InlineScript { Remove-Item -Path $using:Path; };
}

test