openclaw

关注公众号 jb51net

关闭
AI > openclaw >

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

lxmyzzs

问题现象

在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

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

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

Set-ExecutionPolicy Bypass -Scope Process -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提示「拒绝访问」

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

总结

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

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

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