【报错问题】 macOS 的安全策略(Gatekeeper)阻止了未签名的原生模块(bcrypt_lib.node)加载

这个错误是由于 macOS 的安全策略(Gatekeeper)阻止了未签名的原生模块(bcrypt_lib.node)加载 导致的。以下是具体解决方案:


1. 临时允许加载未签名模块(推荐先尝试)

在终端运行以下命令,临时解除限制:

bash 复制代码
sudo xattr -r -d com.apple.quarantine /Users/chengchen/Documents/666\ documents/666/666book/server/node_modules/bcrypt/lib/binding/napi-v3/bcrypt_lib.node

此命令会移除 macOS 对该文件的隔离标记(quarantine)。


2. 完全重建 bcrypt 模块

确保编译环境正确后,彻底重新编译:

bash 复制代码
cd /Users/chengchen/Documents/666\ documents/666/666book/server
npm rebuild bcrypt --update-binary

如果失败,尝试强制重新安装:

bash 复制代码
npm uninstall bcrypt
npm install bcrypt --force

3. 检查 Xcode 命令行工具

确保已安装最新版本:

bash 复制代码
xcode-select --install

然后同意许可协议:

bash 复制代码
sudo xcodebuild -license accept

4. 修改 macOS 安全性设置(谨慎操作)

如果上述方法无效,临时放宽安全策略(仅限开发环境):

  1. 打开系统设置 → 隐私与安全性
  2. 在底部找到提示 "已阻止加载 bcrypt_lib.node" ,点击 "仍要允许"
  3. 重启终端后再运行项目。

5. 终极方案:换用 bcryptjs

如果仍无法解决,使用纯 JavaScript 实现的替代库:

bash 复制代码
npm uninstall bcrypt
npm install bcryptjs

然后在代码中将:

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

替换为:

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

(两者 API 完全兼容,但 bcryptjs 性能略低)


关键原因说明

  • macOS Gatekeeper 会阻止加载未经验证签名的二进制文件(尤其是从网络下载的)。
  • bcrypt 的预编译二进制文件可能因路径含空格(666 documents)或权限问题被标记为不安全。
  • 解决方案的核心是 让系统信任该文件绕过限制(仅限开发环境)。
相关推荐
大熊猫侯佩18 小时前
升级到 macOS26.5 后看视频会自动息屏的解决
macos·操作系统
磊 子20 小时前
C++ IO 流
macos·objective-c·cocoa
real_haha20 小时前
我做了一个仅有 1.3 MB 的 macOS 原生 AI 助手:AskNow
人工智能·macos
June bug1 天前
(Mac)macOS x86_64上onnxruntime==1.24.4 安装失败
macos
ACP广源盛139246256731 天前
iOS 27 开放 AI 生态@ACP#小型化扩展黄金风口,IX8008全面超越 ASM2806,铸就嵌入式 AI 扩展核心
人工智能·嵌入式硬件·macos·ios·计算机外设·objective-c·cocoa
海的辽阔2 天前
如何在MAC下安装EcomGpt模型
macos·大模型·ecomgpt
zandy10112 天前
hermes agent 安装教程 3.0:Win / Mac / Linux 全平台指南
linux·运维·macos
花开·莫之弃2 天前
Mac安装多版本jdk(jenv)
java·开发语言·macos
June bug2 天前
(Mac)torch==2.1.2 与 Python 3.12 不兼容+onnxruntime-silicon 不支持 Intel Mac
开发语言·python·macos
码农小北2 天前
MAC 配置鸿蒙(HarmonyOS) SDK 环境变量完整指南
macos·华为·harmonyos