通过白名单解决 pnpm i 报错 Ignored build scripts

通过白名单解决 pnpm i 报错 Ignored build scripts

问题背景

在执行 pnpm devpnpm install 命令时,遇到以下错误:

bash 复制代码
[ERR_PNPM_IGNORED_BUILDS] Ignored build scripts: core-js@3.45.1, esbuild@0.25.1

Run "pnpm approve-builds" to pick which dependencies should be allowed to run scripts.

此错误表明 pnpm 的安全策略阻止了 core-jsesbuild 包的构建脚本执行,导致依赖安装失败。

解决方案

工作空间级别配置(pnpm-workspace.yaml)

在项目根目录创建或修改 pnpm-workspace.yaml 文件,添加 allowBuilds 配置:

yaml 复制代码
allowBuilds:
  core-js: true
  esbuild: true

配置说明:

  • allowBuilds 是 pnpm 的官方白名单机制
  • 将需要运行构建脚本的包名设为 true,允许其执行安装脚本
  • 此配置在工作空间级别生效,适用于所有子包

包级别配置(package.json)

package.json 中添加 pnpm.onlyBuiltDependencies 配置:

json 复制代码
{
  "pnpm": {
    "onlyBuiltDependencies": [
      "core-js",
      "esbuild"
    ]
  }
}

配置说明:

  • onlyBuiltDependencies 指定仅允许这些包运行构建脚本
  • 此配置在包级别生效,让策略更加清晰可见
  • 确保自动化安装不会被 pnpm 的安全策略拦截

配置原理

pnpm 构建脚本安全机制

pnpm 默认会拦截所有包的构建脚本(postinstallpreinstall 等),这是一种安全措施,防止恶意包在安装时执行危险代码。

当首次安装包含构建脚本的包时,pnpm 会提示用户确认是否允许执行。但在自动化环境(如 CI/CD)中,这种交互式确认会导致安装失败。

双重配置的优势

配置层级 文件位置 作用范围 优势
工作空间级别 pnpm-workspace.yaml 所有子包 统一管理,一次配置全局生效
包级别 package.json 当前包 清晰声明依赖,便于维护

为什么 core-jsesbuild 会出现问题?

1. esbuild:为了获取底层原生二进制文件(核心刚需)

  • 为什么需要脚本esbuild 是用 Go 语言编写的,为了达到极高的编译速度,它在运行时并不依赖 Node.js 引擎,而是依赖针对不同操作系统(Windows、macOS、Linux)和 CPU 架构(x86、ARM64)预编译的原生二进制文件 。在安装时,esbuildpostinstall 脚本会检测你当前的系统环境,并自动去拉取或链接对应的可执行文件(例如 @esbuild/darwin-arm64)。
  • 被拦截的后果 :如果这个脚本被 pnpm 阻止,底层的二进制文件就不会被正确下载或配置。当你尝试启动项目(比如使用依赖 esbuild 的 Vite 时),就会因为找不到底层的执行程序而直接崩溃报错。

2. core-js:为了输出控制台提示信息(非核心功能)

  • 为什么需要脚本core-js 是 JavaScript 生态中最基础的 Polyfill 库之一。由于这是一个个人维护且被极其广泛使用的开源项目,作者在项目的 postinstall 阶段加入了一段脚本,用于在依赖安装完成后,在终端打印一条包含"求职"或"赞助(Funding)"信息的提示,有时也会附带一些简单的环境检查。
  • 被拦截的后果 :如果不执行这段脚本,core-js 的核心代码其实完全可以正常工作 。但只要该包声明了 postinstall 动作,pnpm 的安全机制就会一视同仁地将其捕获,并抛出 [ERR_PNPM_IGNORED_BUILDS] 错误,强制要求开发者确认。
相关推荐
沪漂阿龙1 小时前
字节跳动大模型面试题深度拆解:项目深挖、SFT 与 RLHF、Claude Code、记忆机制、并发锁与手撕题全攻略
人工智能·面试
knight_9___2 小时前
大模型project面试3
人工智能·python·语言模型·面试·大模型·agent
布局呆星2 小时前
Vue Router 笔记(二):正则路由、组件通信与动态路由
前端·javascript·vue.js
Makoto_Kimur2 小时前
Java 后端面试场景题:页面刷新后一直转圈,应该怎么排查?
java·开发语言·面试
芝士爱知识a3 小时前
2026 年教资面试考前急救软件推荐:基于智蛙面试app的技术评测
面试·职场和发展·智蛙面试·教资面试软件·ai模拟面试·教资考前急救·多模态大模型应用
rising start3 小时前
InsightEdu - 轻量智能学习平台
javascript·axios·css3·html5·fastapi·orm·dify
AI人工智能+电脑小能手3 小时前
【大白话说Java面试题 第53题】【JVM篇】第13题:JVM采用什么算法判断一个对象是否需要被回收?
java·jvm·算法·面试
小赵不会秃头3 小时前
数据结构Day 06:线性结构、库操作及 Makefile 完整学习笔记
java·linux·数据结构·算法·面试
qq_381338503 小时前
前端虚拟列表与无限滚动性能优化实战:从万级数据到丝滑体验
前端·javascript·html·优化