我正在尝试运行从cmd.exe调用PowerShell脚本的cmd文件,但遇到以下错误:

无法加载Management_Install.ps1,因为在此系统上禁用了脚本的执行。

我运行了以下命令:

Set-ExecutionPolicy -ExecutionPolicy Unrestricted

当我从PowerShell运行Get-ExecutionPolicy时,它返回Unrestricted。

Get-ExecutionPolicy

输出:

Unrestricted

cd“C:\Projects\Microsoft.Practices.ESB\Source\Samples\Management Portal\Install\Scripts”powershell。\管理安装.ps1 1警告:正在运行x86 PowerShell。。。无法加载文件C:\Projects\Microsoft.Practices.ESB\Source\Samples\Management Portal\Install\Scripts\Management_Install.ps1,因为在此系统上禁用了脚本的执行。有关详细信息,请参阅“get-helpabout_signing”。第1行字符:25.\Management_Install.ps1<<<1类别信息:未指定:(:)[],PSSecurityExceptionFullyQualifiedErrorId:运行时异常C: \Projects\Microsoft.Practices.ESB\Source\Samples\Management Portal\Install\Scripts>PAUSE按任意键继续。


系统为Windows Server 2008 R2。

我做错了什么?


如果您使用的是Windows Server 2008 R2,则存在x64和x86版本的PowerShell,这两个版本都必须设置执行策略。您是否在两台主机上都设置了执行策略?

作为管理员,您可以通过在PowerShell窗口中键入以下内容来设置执行策略:

Set-ExecutionPolicy RemoteSigned

有关详细信息,请参阅使用Set ExecutionPolicy Cmdlet。

完成后,可以使用以下方法将策略设置回其默认值:

Set-ExecutionPolicy Restricted

您可能会看到一个错误:

Access to the registry key
'HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\PowerShell\1\ShellIds\Microsoft.PowerShell' is denied. 
To change the execution policy for the default (LocalMachine) scope, 
  start Windows PowerShell with the "Run as administrator" option. 
To change the execution policy for the current user, 
  run "Set-ExecutionPolicy -Scope CurrentUser".

因此,您可能需要运行如下命令(如注释所示):

Set-ExecutionPolicy RemoteSigned -Scope CurrentUser

RemoteSigned:您自己创建的所有脚本都将运行,所有从Internet下载的脚本都需要由可信的发布者签名。

好的,只需键入以下内容即可更改策略:

Set-ExecutionPolicy RemoteSigned

在运行PowerShell时,可以通过添加-ExecutionPolicy bypass来绕过单个文件的此策略

powershell -ExecutionPolicy Bypass -File script.ps1

在脚本之前运行此命令也可以解决问题:

Set-ExecutionPolicy Unrestricted

设置执行策略是特定于环境的。如果您试图从正在运行的x86 ISE执行脚本,则必须使用x86 PowerShell设置执行策略。同样,如果您正在运行64位ISE,则必须使用64位PowerShell设置策略。


在Windows 7中:

转到“开始”菜单并搜索“Windows PowerShell ISE”。

右键单击x86版本并选择“以管理员身份运行”。

在顶部,粘贴SetExecutionPolicy RemoteSigned;运行脚本。选择“是”。

对64位版本的Powershell ISE(非x86版本)也重复这些步骤。

我只是在澄清Chad Miller暗示的步骤。谢谢Chad!


我遇到了类似的问题,并注意到Windows Server 2012上的默认cmd运行的是x64版本。

对于Windows 11、Windows 10、Windows 7、Windows 8、Windows Server 2008 R2或Windows Server 2012,请以管理员身份运行以下命令:

x86(32位)打开C:\Windows\SysWOW64\cmd.exe运行命令powershell Set ExecutionPolicy RemoteSigned

x64(64位)打开C:\Windows\system32\cmd.exe运行命令powershell Set ExecutionPolicy RemoteSigned

您可以使用检查模式

在CMD中:echo%PROCESSOR_ARCHITECURE%在Powershell中:[Environment]::Is64BitProcess

参考文献:MSDN-Windows PowerShell执行策略Windows-32位vs 64位目录说明


如果您所处的环境不是管理员,则可以仅为您(当前用户)设置执行策略,而不需要管理员。

您可以将其设置为RemoteSigned:

Set-ExecutionPolicy -Scope "CurrentUser" -ExecutionPolicy "RemoteSigned"

或不受限制:

Set-ExecutionPolicy -Scope "CurrentUser" -ExecutionPolicy "Unrestricted"

您可以在帮助条目中阅读有关获取和设置执行策略的所有信息:

Help Get-ExecutionPolicy -Full
Help Set-ExecutionPolicy -Full

如果您在这里是因为使用Ruby或Chef运行它并使用“”系统执行,请执行如下操作:

`powershell.exe -ExecutionPolicy Unrestricted -command [Environment]::GetFolderPath(\'mydocuments\')`

该命令用于获取“MyDocuments”文件夹。

-ExecutionPolicy Unrestricted就是这样。

我希望这对其他人有帮助。


大多数现有的答案解释了“如何”,但很少有人解释“为什么”。在你到处执行来自互联网上陌生人的代码,尤其是禁用安全措施的代码之前,你应该清楚自己在做什么。这里有关于这个问题的更多细节。

从TechNet关于执行策略页面:

Windows PowerShell执行策略允许您确定Windows PowerShell加载配置文件和运行脚本的条件。

如PowerShell基础知识-执行策略和代码签名所述,其优点如下:

执行控制-控制执行脚本的信任级别。Command Highjack-防止在我的路径中注入命令。身份-是由我信任的开发人员创建和签名的脚本,和/或使用我信任的证书颁发机构的证书签名的脚本。完整性-恶意软件或恶意用户无法修改脚本。

要检查当前的执行策略,可以运行GetExecutionPolicy。但你来这里可能是因为你想改变它。

为此,您将运行Set-ExecutionPolicy cmdlet。

在更新执行策略时,您需要做出两个主要决定。

执行策略类型:

受限†-系统上不能执行本地、远程或下载的脚本。AllSigned-运行的所有脚本都需要数字签名。RemoteSigned-所有远程脚本(UNC)或下载的脚本都需要签名。无限制-任何类型的脚本都不需要签名。

新变更的范围

LocalMachine†-执行策略影响计算机的所有用户。CurrentUser-执行策略仅影响当前用户。进程-执行策略仅影响当前的Windows PowerShell进程。

†=默认

例如:如果要将策略更改为仅针对CurrentUser的RemoteSigned,则需要运行以下命令:

Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser

注意:要更改执行策略,必须以管理员身份运行PowerShell。如果您处于常规模式并尝试更改执行策略,则会出现以下错误:

拒绝访问注册表项“HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Shell\1\ShellIds\Microsoft.PowerShell”。要更改默认(LocalMachine)作用域的执行策略,请使用“以管理员身份运行”选项启动Windows PowerShell。

如果要加强对尚未从Internet下载的脚本(或至少不包含UNC元数据)的内部限制,可以强制策略仅运行已签名的脚本。要签署自己的脚本,可以按照Scott Hanselman关于签署PowerShell脚本的文章中的说明进行操作。

注意:大多数人在打开PowerShell时都可能会遇到此错误,因为PowerShell启动时首先要做的是执行用户配置文件脚本,该脚本可以根据您的喜好设置环境。

文件通常位于:

%UserProfile%\My Documents\WindowsPowerShell\Microsoft.PowerShellISE_profile.ps1

您可以通过运行PowerShell变量找到准确的位置

$profile

如果配置文件中没有您关心的内容,并且不想对您的安全设置大惊小怪,您只需删除它,PowerShell将不会发现它无法执行的任何内容。


在PowerShell ISE编辑器中,我发现运行以下第一行允许的脚本。

Set-ExecutionPolicy RemoteSigned -Scope Process

我发现这一行最适合我的一台Windows Server 2008 R2服务器。其他一些人在我的PowerShell脚本中没有这行代码时没有问题:

Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Force -Scope Process

我正在使用Windows 10,无法运行任何命令。唯一能给我一些线索的命令是:

〔x64〕

以管理员身份打开C:\Windows\SysWOW64\cmd.exe运行命令>powershell Set ExecutionPolicy Unrestricted

但这并不奏效。这是有限的。可能是Windows10的新安全策略。我出现了以下错误:

Set ExecutionPolicy:Windows PowerShell已成功更新您的执行策略,但该设置被在更特定范围内定义的策略覆盖。由于重写,您的shell将保留其当前有效的执行策略。。。

所以我找到了另一种方法(解决方案):

打开运行命令/控制台(Win+R)类型:gpedit.msc(组策略编辑器)浏览到本地计算机策略->计算机配置->管理模板->Windows组件->Windows Powershell。启用“启用脚本执行”根据需要设置策略。我将我的设置为“允许所有脚本”。

现在打开PowerShell并享受;)


在PowerShell 2.0中,执行策略默认设置为禁用。

从那时起,PowerShell团队做了很多改进,他们相信用户在运行脚本时不会破坏很多东西。因此,从PowerShell 4.0开始,默认情况下会启用它。

在您的情况下,从PowerShell控制台键入Set-ExecutionPolicy RemoteSigned,然后说yes。


有几个答案指向执行策略。然而,有些事情也需要“runas管理员”。这是最安全的,因为执行策略没有永久性更改,并且可以通过管理员限制。与schedask一起使用以启动批处理:

    runas.exe /savecred /user:administrator powershell -ExecutionPolicy ByPass -File script.ps1

上面的Jack Edmonds和文章的Peter Mortensen/Dhana如何在命令提示符下以“以管理员身份运行”运行应用程序?


我们可以通过以下命令获取当前ExecutionPolicy的状态:

Get-ExecutionPolicy

默认情况下,它是受限的。为了允许执行PowerShell脚本,我们需要将此ExecutionPolicy设置为Unrestricted或Bypass。

我们可以使用以下任何PowerShell命令将当前用户的策略设置为绕过:

Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Unrestricted -Force

Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Bypass -Force

无限制策略加载所有配置文件并运行所有脚本。如果您运行的是从Internet下载的未签名脚本,则会在运行前提示您获得许可。

而在Bypass策略中,在脚本执行过程中不会阻止任何内容,也不会出现任何警告或提示。BypassExecutionPolicy比Unrestricted更宽松。


转到注册表路径HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Shell\1\ShellIds\Microsoft.PowerShell,并将ExecutionPolicy设置为RemoteSigned。


您也可以使用以下命令绕过此问题:

powershell Get-Content .\test.ps1 | Invoke-Expression

您还可以阅读Scott Sutherland的这篇文章,其中介绍了如果您没有管理员权限,绕过PowerShell Set ExecutionPolicy的15种不同方法:

绕过PowerShell执行策略的15种方法


以管理员身份打开PowerShell窗口。这会奏效的。


Win+R并键入复制粘贴命令,然后按OK:

powershell Set-ExecutionPolicy -Scope "CurrentUser" -ExecutionPolicy "RemoteSigned"

然后执行脚本。

然后恢复更改,如:

powershell Set-ExecutionPolicy -Scope "CurrentUser" -ExecutionPolicy "AllSigned"

我今天也有同样的问题。64位执行策略不受限制,而32位执行策略受到限制。

以下是如何远程更改32位策略:

Invoke-Command -ComputerName $servername -ConfigurationName Microsoft.PowerShell32 -scriptblock {Set-ExecutionPolicy unrestricted}

以管理员身份打开PowerShell并运行Set ExecutionPolicy-Scope CurrentUser提供RemoteSigned并按Enter键运行集执行策略-作用域CurrentUser提供无限制并按Enter键


您可以使用特殊方式绕过它:

Get-Content "PS1scriptfullpath.ps1" | Powershell -NoProfile -

它将PowerShell脚本的内容通过管道传输到PowerShell.exe,并绕过执行策略执行它。


打开Windows PowerShell命令窗口并运行以下查询以更改ExecutionPolicy:

设置ExecutionPolicy-ExecutionPolicy RemoteSigned-作用域CurrentUser

如果要求确认更改,请按Y键并按Enter键。


尝试运行Set-ExecutionPolicy RemoteSigned时收到另一个警告

我用这个命令解决了

Set-ExecutionPolicy "RemoteSigned" -Scope Process -Confirm:$false

Set-ExecutionPolicy "RemoteSigned" -Scope CurrentUser -Confirm:$false

打开cmd而不是powershell。这对我有帮助。。。


您可以尝试此操作并选择“全部”选项

Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned

以管理员身份打开Powershell控制台,然后设置执行策略

Set-ExecutionPolicy -ExecutionPolicy Remotesigned 

运行Set ExecutionPolicy RemoteSigned命令


打开运行命令/控制台(Win+R)类型:gpedit。msc(组策略编辑器)浏览到本地计算机策略->计算机配置->管理模板->Windows组件->Windows Powershell。启用“启用脚本执行”根据需要设置策略。我将我的设置为“允许所有脚本”。

现在运行运行命令,无论您使用什么。。相信这一点,应用程序将运行。。享受:)


我也面临过类似的问题。试试这个。

在使用Windows时,我遵循了以下步骤。以管理员身份打开命令提示符,然后转到以下路径:

C:\Users\%username%\AppData\Roaming\npm\

在此文件夹(目录)中查找文件ng.ps1然后删除它(delng.ps1)。

您也可以在这之后清除npm缓存,尽管它也可以在不执行此步骤的情况下工作。


Set-ExecutionPolicy RemoteSigned

在PowerShell中以管理员模式执行此命令将解决此问题。


删除C:\Users[your user]\AppData\Roaming\npm中的ng.ps1文件。

然后删除C:\Users\USER\AppData\Roaming中的npm缓存文件。


在窗口10中:

如果您不是管理员,可以使用此选项:

powershell Set-ExecutionPolicy -Scope CurrentUser

cmdlet Set-ExecutionPolicy at command pipeline position 1
Supply values for the following parameters:
ExecutionPolicy: `RemoteSigned`

它像符咒一样解决了我的问题!


在Windows中打开命令提示符。如果问题仅与PowerShell有关,请使用以下命令:

powershell Set-ExecutionPolicy -Scope "CurrentUser" -ExecutionPolicy "RemoteSigned"

您应该运行以下命令:

Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Unrestricted

对于Windows 11。。。

这确实很容易。只需打开设置应用程序。导航到隐私和安全:

单击For Developers并滚动到底部,找到PowerShell选项,在该选项下选中“Change the execution policy…remote scripts”(更改执行策略…远程脚本)复选框。


在Windows 10中,启用名称为“从任何源安装应用程序,包括松散文件”的选项

它为我解决了这个问题。


首先,您需要打开PowerShell窗口并运行此命令。

set ExecutionPolicy RemoteSigned-作用域CurrentUser

然后它会要求您确认。键入Y并按Enter键。

运行此命令时,可以看到系统已将当前用户的所有策略设置为远程。完成此过程需要几秒钟。

图像如下所示:

检查执行策略是否已设置。类型:

获取执行策略

如果设置了它,输出将如下所示:


以管理员身份打开PowerShell。运行以下命令

设置ExecutionPolicy RemoteSigned

询问时键入Y!


这也发生在我身上。对我来说,解决方案很简单。我没有意识到命令提示符中运行Nodemon的路径与安装包的位置不同。

所以它给了我你提到的同样的错误。

改变我的路径解决了这个问题。


现有答案中有很多信息,但让我尝试系统概述一下:

上下文

PowerShell的有效执行策略适用:

例如,仅脚本文件(.ps1),而不是对cmdlet(例如Get-ChildItem)的调用。仅在Windows上(即,在类Unix平台(Linux、macOS)上,执行策略不适用)

在Windows的工作站版本上,默认情况下禁用脚本文件执行(策略受限),需要对策略进行永久性修改以启用脚本文件,或者在调用PowerShell CLI、PowerShell.exe(Windows PowerShell版本)/pwsh.exe(PowerShell(核心)版本)时通过-ExecutionPolicy参数进行仅限当前进程的修改。

执行策略单独维护:

对于两个PowerShell版本:旧版(仅限Windows)随Windows Windows PowerShell版本(其最新版本为v5.1.x)一起提供现代、跨平台、按需安装PowerShell(Core)版本(v6+)。适用于32位和64位版本的Windows PowerShell(这两个版本都已预安装)注意:如果要并排安装32位和64位版本的PowerShell(Core)(这是不寻常的),则只有LocalMachine作用域是位特定的。

对于给定的PowerShell版本/位组合,可以在多个作用域中设置执行策略,但基于优先级规则,只有一个有效策略-请参见下文。

细节

在Windows上的PowerShell中,默认情况下在Windows工作站版本中禁用脚本文件执行(在Unix上,执行策略不适用);也就是说,Windows工作站版本中的默认执行策略是受限的,而在服务器版本中,它是远程签名的;有关所有可用策略的说明,请参阅概念性的about_Execution_Policies帮助主题。要设置允许脚本执行的(本地)策略,请使用SetExecutionPolicy。使用-Scope参数,SetExecutionPolicy可以针对三个作用域(见下文);更改LocalMachine范围需要提升(以管理员身份运行)。要在给定范围内取消设置以前设置的策略,请使用“未定义”RemoteSigned是一种在安全性和便利性之间提供平衡的常用策略,它允许本地脚本(包括来自网络共享的脚本)在不包含签名的情况下执行,同时要求对从internet下载的脚本进行签名(假设下载机制将脚本标记为internet源,这是默认情况下web浏览器所做的)。例如,要将当前用户的执行策略设置为RemoteSigned,请运行以下命令:设置ExecutionPolicy-作用域CurrentUser RemoteSigned-强制PowerShell CLI(PowerShell.exe for Windows PowerShell,pwsh.exe for PowerShell(Core),v6+)也接受特定于进程的-ExecutionPolicy<policy>参数,该参数通常用于临时策略覆盖(仅用于正在创建的进程,相当于Set ExecutionPolicy-Scope process..);例如。:pwsh.exe-远程签名的执行策略-文件someScript.ps1重要信息:还可以通过组策略对象(GPO)设置执行策略,在这种情况下,不能使用set ExecutionPolicy或CLI更改或覆盖执行策略。执行策略可以在不同的作用域中设置,哪个作用域有效取决于它们的优先级(运行Get-ExecutionPolicy-List以查看所有作用域及其各自的策略),按降序排列:MachinePolicy(通过GPO;无法在本地重写)UserPolicy(通过GPO;无法在本地重写)进程(仅限当前进程;通常通过CLI设置临时)当前用户(由set ExecutionPolicy设置)LocalMachine(由set ExecutionPolicy设置,具有管理员权限)


如果您安装了Git,只需使用GitBash。


要解决此问题,我们必须设置执行策略,以便PowerShell脚本在特定计算机上运行。以下是方法:

通过选择“以管理员身份运行”打开PowerShell控制台,并使用以下命令设置执行策略:set ExecutionPolicy RemoteSigned当提示继续时,键入“Y”

信用:https://www.sharepointdiary.com/2014/03/fix-for-powershell-script-cannot-be-loaded-because-running-scripts-is-disabled-on-this-system.html


以“以管理员身份运行”的身份运行cmd或powershell


对于下载的文件,右键单击→ 财产

然后单击取消阻止并单击确定。然后运行PowerShell脚本,它将不再抱怨无法运行。


在我的情况下,发生这种情况是因为我使用PowerShell,我应该使用cmd提示符


“无法加载,因为在此系统上禁用了运行脚本”的解决方案:如何启用此系统错误时禁用运行脚本?要解决此问题,我们必须设置执行策略,以便PowerShell脚本在特定计算机上运行。此处允许执行PowerShell脚本:

通过选择“以管理员身份运行”打开PowerShell控制台,并使用以下命令获取执行策略:GetExecutionPolicy以获取应用的当前策略,例如“受限”。使用以下命令设置执行策略:Set ExecutionPolicy RemoteSigned当提示继续时,键入“Y”。