npm 上的包可以在其 package.json 文件中定义_生命周期脚本_。下面是一些最常见的脚本,但实际上还有许多其他脚本。
preinstall:包安装前运行postinstall:包安装后运行preuninstall:包卸载前运行prepublishOnly:包发布前运行
npm 客户端不同——Bun 默认不执行任意的生命周期脚本。
postinstall
postinstall 脚本尤其重要。它被广泛用于构建或安装平台特定的二进制文件,这些包通常实现为本地 Node.js 插件(native add-ons)。例如,node-sass 是一个流行的包,使用 postinstall 来构建 Sass 的本地二进制文件。
package.json
trustedDependencies
Bun 采取“默认安全”的策略,而不是执行任意脚本。你可以将某些包添加到允许列表中,Bun 会为这些包执行生命周期脚本。要允许 Bun 执行特定包的生命周期脚本,只需在你的 package.json 中将该包名添加到 trustedDependencies 数组。
package.json
trustedDependencies 后,安装或重新安装该包。Bun 会读取此字段并运行对应包的生命周期脚本。
默认情况下,前 500 个带生命周期脚本的 npm 包是被允许的。你可以在这里查看完整名单。
默认信任的依赖列表仅适用于从 npm 安装的包。对于来自其他来源的包(例如
file:、link:、git: 或 github: 依赖),即使包名匹配默认列表中的条目,也必须显式将其添加到 trustedDependencies 中才能运行它们的生命周期脚本。这样可以防止恶意包通过本地文件路径或 git 仓库伪装成受信任包。--ignore-scripts
如果想禁用所有包的生命周期脚本,可以使用 --ignore-scripts 参数。
terminal