解决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 绕过所有执行策略限制(仅临时使用)
相关推荐
hzhsec18 小时前
密码爆破日志分析与隧道流量检查
linux·网络·windows·网络安全·应急响应
We་ct18 小时前
LeetCode 136. 只出现一次的数字:线性时间+常量空间最优解拆解
前端·算法·leetcode·typescript·位运算
HAPPY酷18 小时前
3A游戏图形设置终极优化指南:从通用法则到实战应用
java·前端·游戏
达达爱吃肉18 小时前
openclaw 4.2 飞书出图的bug
java·前端·数据库
lightqjx18 小时前
【前端】前端学习二之CSS
前端·css·学习·html
IT东18 小时前
Vue 多环境部署全解析:解决测试与生产一致性难题
前端·javascript·vue.js
of Watermelon League18 小时前
Redis 通用命令
前端·redis·bootstrap
chxii18 小时前
配置Nginx 的 Keepalive 提升每秒查询率(QPS)
前端·nginx
humors22118 小时前
[原创]AI工具:手机文件查杀病毒工具
windows·ios·手机·安卓·鸿蒙·杀毒·苹果
xnkyn18 小时前
frp内网穿透https访问本地服务,frpee客户端https教程
前端·后端·网络协议·http·https