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

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

问题现象

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

powershell 复制代码
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

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

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

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

powershell 复制代码
Set-ExecutionPolicy Bypass -Scope Process -Force

参数说明

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

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

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

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

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

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

powershell 复制代码
Set-ExecutionPolicy RemoteSigned -Scope CurrentUser -Force

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

验证安装结果

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

powershell 复制代码
openclaw --version

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

常见问题排查

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

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

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

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

总结

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

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

执行策略 说明
Restricted 默认值,禁止运行任何脚本
AllSigned 仅允许运行已签名的脚本(本地/远程均需签名)
RemoteSigned 本地脚本可运行,远程脚本需签名(推荐开发环境使用)
Unrestricted 允许运行所有脚本(不推荐,有安全风险)
Bypass 绕过所有执行策略限制(仅临时使用)
相关推荐
江南十四行14 小时前
AI Agent应用类型及Function Calling开发实战(三)
服务器·前端·javascript
GISer_Jing14 小时前
AI原生全栈架构理论体系:从分布式范式演进到全链路工程化理论基石
前端·人工智能·学习·ai编程
GISer_Jing14 小时前
从“切图仔”到“增长架构师”:AI时代营销前端的范式革命
前端·人工智能·ai编程
广州华水科技14 小时前
单北斗GNSS在水库变形监测中的应用与系统安装解析
前端
xingpanvip14 小时前
星盘接口开发文档:组合三限盘接口指南
android·开发语言·前端·python·php·lua
AI周红伟14 小时前
数字人,视频,图片用不过时
大数据·人工智能·搜索引擎·copilot·openclaw
阿拉丁的梦14 小时前
blender最好的多通道吸色工具(拾取纹理颜色排除灯光)
前端·html
吴声子夜歌14 小时前
Vue3——脚手架Vite
前端·javascript·vue.js·vite
摘星编程14 小时前
当AI开始学会“使用工具“——从ReAct到MCP,大模型如何获得真正的行动力
前端·人工智能·react.js
疋瓞15 小时前
批处理_基础补充、文件和文件夹处理_02
windows