执行PowerShell脚本提示“see about_Execution_Policies at https://go.microsoft.com/fwlink/?LinkID=135170”

长说明

PowerShell 执行策略是一项安全功能,用于控制 PowerShell 加载配置文件和运行脚本的条件。 此功能有助于防止恶意脚本的执行。

在 Windows 计算机上,可以为本地计算机、当前用户或特定会话设置执行策略。 还可使用组策略设置为计算机和用户设置执行策略。

本地计算机和当前用户的执行策略存储在注册表中。 无需在 PowerShell 配置文件中设置执行策略。 特定会话的执行策略仅存储在内存中,在会话关闭时会丢失。

执行策略不是限制用户操作的安全系统。 例如,当用户无法运行脚本时,可以通过在命令行中键入脚本内容来轻松绕过策略。 相反,执行策略可帮助用户设置基本规则,并防止他们无意中违反这些规则。

在非 Windows 计算机上,默认执行策略是 Unrestricted 且无法更改。 cmdlet Set-ExecutionPolicy 可用,但 PowerShell 会显示一条控制台消息,指出它不受支持。 虽然Get-ExecutionPolicy在非 Windows 平台上返回Unrestricted,但该行为确实匹配,Bypass因为这些平台不实现Windows 安全中心区域。

PowerShell 执行策略

仅在 Windows 平台上强制执行这些策略。 PowerShell 执行策略如下所示:

AllSigned

1、脚本可以运行。
2、要求所有脚本和配置文件都由受信任的发布者签名,包括在本地计算机上编写的脚本。
3、从尚未分类为受信任或不受信任的发布者运行脚本之前,会提示你。
4、运行已签名但恶意脚本的风险。

Bypass

1、不阻止任何操作,并且没有任何警告或提示。
2、此执行策略适用于 PowerShell 脚本内置于较大应用程序的配置,或针对 PowerShell 是具有自身安全模型的程序基础的配置。

Default

1、设置默认执行策略。
2、Restricted 适用于 Windows 客户端的 。
3、适用于 Windows 服务器的 RemoteSigned

RemoteSigned

1、Windows Server 计算机的默认执行策略。
2、脚本可以运行。
3、需要受信任的发布者对从 Internet 下载的脚本和配置文件(包括电子邮件和即时消息程序)的数字签名。
4、不需要在本地计算机上编写且未从 Internet 下载的脚本上使用数字签名。
5、如果未阻止脚本(例如使用 cmdlet),则运行从 Internet 下载且未签名的 Unblock-File 脚本。
6、运行来自 Internet 以外的源的未签名脚本以及可能是恶意的已签名脚本的风险。

Restricted

1、Windows 客户端计算机的默认执行策略。
2、允许单个命令,但不允许脚本。
3、阻止运行所有脚本文件,包括格式化和配置文件 () .ps1xml 、模块脚本文件 (.psm1) ,以及 PowerShell 配置文件 () .ps1 。

Undefined

1、当前范围内没有设置执行策略。
2、如果所有范围内的执行策略都是 Undefined,则有效的执行策略 Restricted 适用于 Windows 客户端, RemoteSigned 适用于 Windows Server。


Unrestricted

1、非 Windows 计算机的默认执行策略,无法更改。
2、未签名的脚本可以运行。 存在运行恶意脚本的风险。
3、在运行不来自本地 Intranet 区域的脚本和配置文件之前警告用户。

 备注:
在未区分通用命名约定 (UNC) 路径与 Internet 路径的系统上,可能不允许使用 RemoteSigned 执行策略运行由 UNC 路径标识的脚本。

执行策略范围

可以设置仅在特定范围内有效的执行策略。

的有效值为 ScopeMachinePolicyUserPolicyProcessCurrentUser 和 LocalMachine。 设置执行策略时,LocalMachine 是默认设置。

这些 Scope 值按优先顺序列出。 优先策略在当前会话中有效,即使在较低优先级上设置了限制性更高的策略也是如此。

有关详细信息,请参阅 Set-ExecutionPolicy

MachinePolicy

由组策略为计算机的所有用户设置。

UserPolicy

由计算机当前用户的组策略设置。

Process

范围 Process 仅影响当前 PowerShell 会话。 执行策略保存在环境变量 $env:PSExecutionPolicyPreference中,而不是注册表中。 关闭 PowerShell 会话时,变量和值将被删除。

CurrentUser

执行策略仅影响当前用户。 它存储在 HKEY_CURRENT_USER 注册表子项中。

LocalMachine

执行策略会影响当前计算机上的所有用户。 它存储在 HKEY_LOCAL_MACHINE 注册表子项中。

使用 PowerShell 管理执行策略

若要获取当前 PowerShell 会话的有效执行策略,请使用 Get-ExecutionPolicy cmdlet。

以下命令获取有效的执行策略:

PowerShell复制

Get-ExecutionPolicy

获取影响当前会话的所有执行策略并按优先顺序显示它们:

PowerShell复制

Get-ExecutionPolicy -List

结果类似于以下示例输出:

Output复制

        Scope ExecutionPolicy
        ----- ---------------
MachinePolicy       Undefined
   UserPolicy       Undefined
      Process       Undefined
  CurrentUser    RemoteSigned
 LocalMachine       AllSigned

在这种情况下,有效执行策略为 RemoteSigned ,因为当前用户的执行策略优先于为本地计算机设置的执行策略。

若要获取为特定范围设置的执行策略,请使用 Scope 的 Get-ExecutionPolicy参数。

例如,以下命令获取 CurrentUser 范围的执行策略:

PowerShell复制

Get-ExecutionPolicy -Scope CurrentUser

更改执行策略

若要更改 Windows 计算机上的 PowerShell 执行策略,请使用 Set-ExecutionPolicy cmdlet。 更改将立即生效。 无需重启 PowerShell。

如果为 范围 LocalMachine 或 CurrentUser 设置执行策略,则更改将保存在注册表中,并在再次进行更改之前保持有效。

如果为 Process 范围设置执行策略,则不会将其保存在注册表中。 执行策略将一直保留到当前进程和任何子进程关闭为止。

 备注

在 Windows Vista 和更高版本的 Windows 中,若要运行更改本地计算机( LocalMachine 范围)执行策略的命令,请使用 “以管理员身份运行” 选项启动 PowerShell。

若要更改执行策略,请执行以下操作:

PowerShell复制

Set-ExecutionPolicy -ExecutionPolicy <PolicyName>

例如:

PowerShell复制

Set-ExecutionPolicy -ExecutionPolicy RemoteSigned

若要在特定范围内设置执行策略,请执行以下操作:

PowerShell复制

Set-ExecutionPolicy -ExecutionPolicy <PolicyName> -Scope <scope>

例如:

PowerShell复制

Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

用于更改执行策略的命令可以成功,但仍不能更改有效的执行策略。

例如,为本地计算机设置执行策略的命令可以成功,但会被当前用户的执行策略覆盖。

删除执行策略

若要删除特定范围的执行策略,请将执行策略设置为 Undefined

例如,删除本地计算机所有用户的执行策略:

PowerShell复制

Set-ExecutionPolicy -ExecutionPolicy Undefined -Scope LocalMachine

删除 的执行策略 Scope

PowerShell复制

Set-ExecutionPolicy -ExecutionPolicy Undefined -Scope CurrentUser

如果未在任何范围内设置执行策略,则有效的执行策略为 Restricted,这是 Windows 客户端的默认策略。

为一个会话设置不同的策略

可以使用 的 ExecutionPolicy 参数 pwsh.exe 为新的 PowerShell 会话设置执行策略。 该策略仅影响当前会话和子会话。

若要为新会话设置执行策略,请在命令行(如 cmd.exe 或 )启动 PowerShell,然后使用 的 pwsh.exeExecutionPolicy 参数设置执行策略。

例如:

PowerShell复制

pwsh.exe -ExecutionPolicy AllSigned

设置的执行策略不会存储在注册表中。 而是存储在 环境变量中 $env:PSExecutionPolicyPreference 。 关闭在其中设置了策略的会话时,变量将被删除。 不能通过编辑变量值来更改策略。

在会话期间,为会话设置的执行策略优先于在本地计算机或当前用户的注册表中设置的执行策略。 但是,它不优先于使用组策略设置的执行策略。

使用组策略管理执行策略

可以使用“打开脚本执行组策略设置来管理企业中计算机的执行策略。 组策略设置将覆盖 PowerShell 在所有范围内设置的执行策略。

“打开脚本执行”策略设置如下所示:

  • 如果禁用 “打开脚本执行”,则脚本不会运行。 这等效于 Restricted 执行策略。

  • 如果启用 “打开脚本执行”,则可以选择执行策略。 组策略设置等效于以下执行策略设置:组策略执行策略允许所有脚本Unrestricted允许本地脚本和远程签名脚本RemoteSigned仅允许签名的脚本AllSigned

  • 如果未配置 “打开脚本执行 ”,则不起作用。 PowerShell 中设置的执行策略有效。

PowerShellExecutionPolicy.adm 和 PowerShellExecutionPolicy.admx 文件将打开脚本执行策略添加到组策略编辑器中的“计算机配置”和“用户配置”节点,路径如下。

对于 Windows XP 和 Windows Server 2003:

Administrative Templates\Windows Components\Windows PowerShell

对于 Windows Vista 及更高版本的 Windows:

Administrative Templates\Classic Administrative Templates\Windows Components\Windows PowerShell

在“计算机配置”节点中设置的策略优先于“用户配置”节点中设置的策略。

有关详细信息,请参阅 about_Group_Policy_Settings

执行策略优先级

确定会话的有效执行策略时,PowerShell 将按以下优先顺序评估执行策略:复制

Group Policy: MachinePolicy
Group Policy: UserPolicy
Execution Policy: Process (or pwsh.exe -ExecutionPolicy)
Execution Policy: CurrentUser
Execution Policy: LocalMachine

管理已签名和未签名的脚本

在 Windows 中,Internet Explorer 和 Microsoft Edge 等程序将备用数据流添加到下载的文件。 这会将文件标记为“来自 Internet”。 如果 PowerShell 执行策略为 RemoteSigned,则 PowerShell 不会运行从 Internet 下载的未签名脚本,其中包括电子邮件和即时消息程序。

你可以对脚本进行签名,或者选择在不更改执行策略的情况下运行未签名的脚本。

从 PowerShell 3.0 开始,可以使用 cmdlet 的 Get-ItemStream 参数来检测因从 Internet 下载而阻止的文件。 Unblock-File使用 cmdlet 取消阻止脚本,以便可以在 PowerShell 中运行它们。

有关详细信息,请参阅 about_Signing、 Get-Item 和 Unblock-File

 备注

下载文件的其他方法可能不会将文件标记为来自 Internet 区域。 示例包括:

  • curl.exe

  • Invoke-RestMethod

  • Invoke-WebRequest

Windows Server Core 和 Window Nano Server 上的执行策略

在某些情况下,在 Windows Server Core 或 Windows Nano Server 上运行 PowerShell 6 时,执行策略可能会失败并出现以下错误:

Output复制

AuthorizationManager check failed.
At line:1 char:1
+ C:\scriptpath\scriptname.ps1
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : SecurityError: (:) [], PSSecurityException
    + FullyQualifiedErrorId : UnauthorizedAccess

PowerShell 使用 Windows 桌面 shell (explorer.exe) 中的 API 来验证脚本文件的区域。 Windows Shell 在 Windows Server Core 和 Windows Nano Server 上不可用。

如果 Windows 桌面 Shell 不可用或无响应,你也可能在任何 Windows 系统上收到此错误。 例如,在登录期间,PowerShell 登录脚本可能会在 Windows 桌面准备就绪之前开始执行,从而导致失败。

使用 ByPass 或 AllSigned 的执行策略不需要区域检查,这可以避免此问题。

另请参阅

消息盒子

# 暂无消息 #

只显示最新10条未读和已读信息