创建 OpenSSL Framework 时某些体系结构的未定义符号

Undefined symbols for some architectures when creating OpenSSL Framework

我正在为 OSX/iOS 开发 Swift 框架。我需要生成 RSA 密钥并导出它们,而安全框架不允许在 iOS 上巧妙地执行此操作,因此我将使用 OpenSSL。

我检索到为两个平台构建 OpenSSL 的脚本 (https://gist.github.com/6710405)。它完美运行并为每个平台生成 libcrypto.alibssl.a 和相应的 headers。

我想把 OpenSSL 放在自己的框架中,并定义一个模块以便在 Swift 中使用它。

为了简单起见,我们限制为 OSX。我创建了一个名为 OpenSSL 的新框架项目。我链接了两个库并添加了所有 headers(如 public headers)。我还添加了一个 "Copy files" 阶段,我在其中复制并签署了两个库。我创建了一个 .modulemap 文件:

framework module OpenSSL {

   header "rc2.h"
   header "rc4.h"

   header "aes.h"
   […]
   header "x509v3.h"

   header "dtls1.h"

   export *
}

OpenSSL 的headers全部列出。我最初按字母顺序对 headers 进行了排序,但一些 #undef 导致了问题,所以我不得不重新排序一些 headers 并且它编译(我一点也不喜欢这样!)。

回到原来的框架,我添加了我的OpenSSL框架,导入了OpenSSL模块,写了几行:

import OpenSSL

func generateKeyPair() -> RSAKeyPair? {
    var exponent = BN_new();
    BN_set_word(exponent, 65537);
    var rsa = RSA_new()
    RSA_generate_key_ex(rsa, 2048, exponent, nil)
    […]
}

代码由Xcode完成,它看到了模块的headers。当我尝试编译时,它会为某些(但不是全部)OpenSSL 调用生成一些 Undefined symbols for architecture x86_64:。例如,它抱怨 RSA_generate_key_ex 但不抱怨 BN_set_wordRSA_new()(在 RSA_generate_key_ex 之前几行声明)。它不仅在 RSA_generate_key_ex 时失败,而且稍后其他一些调用也会因同样的错误而失败。

我已经建立了一个 playground 来检查这个。某些对 RSA_new() 的调用正在返回内容,但 playground 无法找到 RSA_generate_key_ex 的符号。

我快速建立了一个新的 Objective-C 项目,添加了库和 headers 经典方式,相同的代码(在 ObjC 中)编译和运行没有问题。因此,我确信这些库是用所有需要的架构构建的(我用 otool 仔细检查过)。

我的框架出了点问题。我尝试 remove/add "Copy files" 阶段但没有成功。我对制作 .modulemap 文件的方式不满意,但我看不出它会在哪里导致此类问题。我不是框架制作方面的专家,所以也许有人知道会发生什么以及如何解决它?

我自己找到了解决方案。像往常一样,框架中需要旧的 -all_load 标志作为 "Other linker flags"。

此外,库不需要复制阶段。链接它们似乎就足够了。