【前端】macOS 的 Gatekeeper 安全机制阻止你加载 bcrypt_lib.node 文件 如何解决

这个弹窗是 macOS 的 Gatekeeper 安全机制 阻止你加载 bcrypt_lib.node 文件,因为它不是 Apple 签名的文件。

你想 "忽视" 它,其实是让系统允许这个 .node 原生模块运行,解决方式如下:

sudo xattr -d com.apple.quarantine node_modules/bcrypt/lib/binding/napi-v3/bcrypt_lib.node

✅ 最直接有效的解决办法(终端允许这个库)

1. 找到你项目中出错的 bcrypt_lib.node 文件路径(例如):

bash 复制代码
node_modules/bcrypt/lib/binding/napi-v3/bcrypt_lib.node

如果不确定路径,运行项目时报错会提示 bcrypt_lib.node 的全路径。


2. 用 终端命令解锁并允许其运行

bash 复制代码
sudo xattr -d com.apple.quarantine node_modules/bcrypt/lib/binding/napi-v3/bcrypt_lib.node

⛳️ 如果你的文件在 napi-v6napi-v1 等路径下,请根据你项目中提示的路径替换。


📌 这个命令的作用:

  • xattr:修改文件的扩展属性
  • -d com.apple.quarantine:删除"隔离标签",告诉系统这不是恶意软件
  • sudo 是因为这个文件夹在 node_modules 下,需要管理员权限

🧩 如果你使用的是 yarnpnpm 安装的 bcrypt:

不同包管理器路径略有不同,也可能是:

bash 复制代码
node_modules/@node-rs/bcrypt/bcrypt_lib.node

一样使用:

bash 复制代码
sudo xattr -d com.apple.quarantine 路径/bcrypt_lib.node

✅ 之后运行你的项目就不会报错了

bash 复制代码
npm run start
# 或
npx expo start

🚫 你不应该"删除"或"忽视"这个库

因为:

  • bcrypt_lib.nodebcrypt 库的核心加密原生模块
  • 忽视/删除它会导致密码无法加密或验证

💡 如果你不想用 bcrypt(可选方案)

你也可以改用纯 JS 实现的 bcryptjs,它没有 native 模块:

bash 复制代码
npm uninstall bcrypt
npm install bcryptjs

使用方式类似:

js 复制代码
const bcrypt = require('bcryptjs');

const hash = await bcrypt.hash(password, 10);
const match = await bcrypt.compare(password, hash);

✅ 总结(推荐你执行的指令):

bash 复制代码
sudo xattr -d com.apple.quarantine node_modules/bcrypt/lib/binding/napi-v3/bcrypt_lib.node

执行后再次运行项目即可。

如果你需要我根据你的报错路径帮你精确拼出这条命令,也可以贴出报错路径或全路径,我来帮你写。

相关推荐
hpoenixf44 分钟前
2026 年前端面试问什么
前端·面试
还是大剑师兰特1 小时前
Vue3 中的 defineExpose 完全指南
前端·javascript·vue.js
泯泷1 小时前
阶段一:从 0 看懂 JSVMP 架构,先在脑子里搭出一台最小 JSVM
前端·javascript·架构
mengchanmian2 小时前
前端node常用配置
前端
华洛2 小时前
利好打工人,openclaw不是企业提效工具,而是个人助理
前端·javascript·产品经理
xkxnq2 小时前
第六阶段:Vue生态高级整合与优化(第93天)Element Plus进阶:自定义主题(变量覆盖)+ 全局配置与组件按需加载优化
前端·javascript·vue.js
todoitbo2 小时前
用虚拟局域网打通 Win/Mac/Linux 三端:跨设备协作的实用方案
linux·运维·macos
彭波3963 小时前
.NET Framework 3.5问题修复教程!可以离线修复
windows·安全·电脑·.net·开源软件
A黄俊辉A3 小时前
vue css中 :global的使用
前端·javascript·vue.js
小码哥_常3 小时前
被EdgeToEdge适配折磨疯了,谁懂!
前端