Bun

指南运行时

在 macOS 上使用 Bun 对单个 JavaScript 可执行文件进行代码签名

解决运行 JavaScript 可执行文件时出现的“无法打开,因为它来自不明开发者”的 Gatekeeper 警告。

使用 `--compile` 标志编译您的可执行文件。

bun build --compile ./path/to/entry.ts --outfile myapp

列出您可用的签名身份。其中一个将是您传递给 `codesign` 命令的签名身份。此命令需要 macOS。

security find-identity -v -p codesigning
1. XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX "Developer ID Application: Your Name (ZZZZZZZZZZ)"
   1 valid identities found

可选但推荐:创建一个 `entitlements.plist` 文件,其中包含 JavaScript 引擎正常工作所需的权限。

entitlements.plist
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>com.apple.security.cs.allow-jit</key>
    <true/>
    <key>com.apple.security.cs.allow-unsigned-executable-memory</key>
    <true/>
    <key>com.apple.security.cs.disable-executable-page-protection</key>
    <true/>
    <key>com.apple.security.cs.allow-dyld-environment-variables</key>
    <true/>
    <key>com.apple.security.cs.disable-library-validation</key>
    <true/>
</dict>
</plist>

使用 `codesign` 命令对您的可执行文件进行签名并验证其是否有效。

codesign --entitlements entitlements.plist -vvvv --deep --sign "XXXXXXXXXX" ./myapp --force
codesign -vvv --verify ./myapp

有关 macOS 代码签名的更多信息,请参阅 Apple 的代码签名文档。有关使用 Bun 创建单个文件可执行文件的详细信息,请参阅 独立可执行文件。本指南需要 Bun v1.2.4 或更高版本。