一文教你解决Windows安装OpenClaw报错:无法加载npm.ps1,禁止运行脚本

  发布时间:2026-03-09 17:24:19   作者:lxmyzzs   我要评论
在Windows PowerShell中执行OpenClaw安装命令时,可能会出现如下权限错误:无法加载npm.ps1,禁止运行脚本,下面小编就和大家详细介绍一下问题出现的原因以及如何解决吧

问题现象

在Windows PowerShell中执行OpenClaw安装命令时,出现如下权限错误:

PS C:\Users\tangyuan> & ([scriptblock]::Create((iwr -useb https://openclaw.ai/install.ps1))) -Tag beta
  OpenClaw Installer
[OK] Windows detected
[!] Node.js not found
[*] Installing Node.js...
# 省略Node.js安装成功日志
[OK] Node.js v24.14.0 found
[*] Installing OpenClaw (openclaw@beta)...
npm : 无法加载文件 C:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本。有关详细信息,请参阅 https:/go.microsoft.com/fwlink/?LinkID=135170 中的 about_Execution_Policies。
所在位置 行:290 字符: 22
+         $npmOutput = npm install -g "$packageName@$Tag" 2>&1
+                      ~~~
    + CategoryInfo          : SecurityError: (:) [],ParentContainsErrorRecordException
    + FullyQualifiedErrorId : UnauthorizedAccess

问题根源

该报错的核心原因是 Windows PowerShell的执行策略限制:Windows默认启用严格的执行策略(默认值为Restricted),禁止运行任何未签名的PowerShell脚本,而npm的核心脚本npm.ps1属于未签名的本地脚本,因此被系统拦截。

解决方案(分步实操)

步骤1:以管理员身份打开PowerShell

  • 按下 Win + X 快捷键,在弹出的菜单中选择「Windows PowerShell (管理员)」(Windows 11为「终端(管理员)」);
  • 弹出用户账户控制(UAC)提示时,点击「是」确认权限。

步骤2:临时放宽执行策略(推荐)

在管理员权限的PowerShell中执行以下命令(仅当前会话生效,重启后恢复默认,安全无风险):

Set-ExecutionPolicy Bypass -Scope Process -Force

参数说明

  • -Scope Process:仅对当前PowerShell进程生效,不修改系统全局策略;
  • -Force:跳过确认提示,直接执行。

步骤3:重新执行OpenClaw安装命令

在同一个管理员PowerShell窗口中,重新运行安装指令:

& ([scriptblock]::Create((iwr -useb https://openclaw.ai/install.ps1))) -Tag beta

可选:永久放宽执行策略(谨慎使用)

如果需要长期使用Node.js/npm,且确认环境安全,可将执行策略改为RemoteSigned(允许本地脚本运行,远程脚本需签名):

Set-ExecutionPolicy RemoteSigned -Scope CurrentUser -Force

注意:该命令对当前用户全局生效,仅建议在个人开发机使用,企业环境需遵循IT规范。

验证安装结果

安装完成后,执行以下命令验证OpenClaw是否成功安装:

openclaw --version

若输出类似 openclaw/x.x.x beta 的版本信息,说明安装成功。

常见问题排查

执行Set-ExecutionPolicy提示「拒绝访问」

  • 确认PowerShell是管理员身份运行;
  • 企业环境可能通过组策略锁定执行策略,需联系IT管理员解除限制。

npm依然报错「无法加载脚本」

  • 重启管理员权限的PowerShell后重试;
  • 验证Node.js安装是否成功:node -v(正常输出v24.14.0即可);
  • 手动检查npm路径:Get-Command npm(应指向C:\Program Files\nodejs\npm.ps1)。

总结

  • Windows默认的PowerShell执行策略是导致npm脚本无法运行的核心原因;
  • 优先使用「临时放宽执行策略」(-Scope Process),兼顾易用性和安全性;
  • 永久修改执行策略仅适用于个人开发环境,生产/企业环境需严格遵循安全规范。

扩展知识:PowerShell执行策略说明

执行策略说明
Restricted默认值,禁止运行任何脚本
AllSigned仅允许运行已签名的脚本(本地/远程均需签名)
RemoteSigned本地脚本可运行,远程脚本需签名(推荐开发环境使用)
Unrestricted允许运行所有脚本(不推荐,有安全风险)
Bypass绕过所有执行策略限制(仅临时使用)

到此这篇关于一文教你解决Windows安装OpenClaw报错:无法加载npm.ps1,禁止运行脚本的文章就介绍到这了,更多相关Windows安装OpenClaw内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!

相关文章

最新评论