为什么规避执行策略会破坏我的脚本?

Why does circumventing execution-policy break my script?

我有一个脚本,它可以将 ISO 复制到 C:\temp,然后安装 ISO 并将驱动器号存储在一个变量中,用于在安装的驱动器上执行文件。我这样做:

$mountinfo = Mount-DiskImage -ImagePath $ctempiso
$driveletter = (($mountinfo | Get-volume).driveletter)
$installpath = "${driveletter}:\setup.exe"

$scriptblock = [scriptblock]::create($installpath)
Invoke-Command -ScriptBlock $scriptblock

如果我手动将执行策略设置为无限制,然后执行我的 PowerShell 脚本,所有这些都可以正常工作。

为了避免必须设置执行策略,我在我 运行 作为管理员的批处理文件中使用了以下内容:

PowerShell.exe -ExecutionPolicy Bypass -File \server.contoso.local\share\test.ps1

当我 运行 批处理文件时,它无法存储驱动器号和 returns 一个错误,它无法执行 ${driveletter}:\setup.exe

我想我的第一个问题是为什么我的脚本在第一种方法而不是第二种方法中工作?

其次,是否有另一种方法可以规避执行策略并让我的脚本 运行 像我想要的那样?

我发现了问题...魔术词是“-passthru”,它在我的代码中丢失了。

 $mountinfo = Mount-DiskImage -ImagePath $ctempiso -Passthru 
$driveletter = (($mountinfo | Get-volume).driveletter) 
$installpath = "${driveletter}:\setup.exe"  

$scriptblock = [scriptblock]::create($installpath) 
Invoke-Command -ScriptBlock $scriptblock