ios - 适用于 iOS 的 S/MIME 电子邮件加密库

标签 ios swift ssl openssl smime

我正在尝试为我在 Swift 中创建的 iOS 电子邮件应用程序查找 S/MIME 电子邮件加密库。我一直无法找到用于加密的库,有没有人有这方面的经验? 我已经尝试过 OpenSSL,但在导入桥接 header 中需要的所有文件时遇到了问题,例如,我需要使用 pem.h 中的函数,但如果我尝试导入 pem.h,则桥接 header 无法完全导入。

如有任何帮助,我们将不胜感激。

最佳答案

我也有类似的需求。最终我不得不导入 openSSL 并编写自己的代码来处理 PKCS7 的解密。我做了一个小的 github repo 应该帮助

https://github.com/zkrige/iOS-pkcs7-decrypt

这是代码的要点

#include <openssl/bio.h>
#include <openssl/cms.h>
#include <openssl/err.h>
#include <openssl/pem.h>
#include <openssl/ssl.h>
#include <openssl/crypto.h>
#include <openssl/rand.h>

X509 *getCert(const char *certificate) {
    BIO *membuf = BIO_new(BIO_s_mem());
    BIO_puts(membuf, certificate);
    X509 *x509 = PEM_read_bio_X509(membuf, NULL, NULL, NULL);
    return x509;
}

EVP_PKEY *getKey(const char *privateKey) {
    BIO *membuf = BIO_new(BIO_s_mem());
    BIO_puts(membuf, privateKey);
    EVP_PKEY *key = PEM_read_bio_PrivateKey(membuf, NULL, 0, NULL);
    return key;
}

PKCS7 *getContainer(const char *encrypted) {
    BIO* membuf = BIO_new(BIO_s_mem());
    BIO_set_mem_eof_return(membuf, 0); 
    BIO_puts(membuf, encrypted);
    PKCS7* pkcs7 = SMIME_read_PKCS7(membuf, NULL);
    if (!pkcs7) {
        fprintf(stderr, "error: %ld\n", ERR_get_error());
    }
    return pkcs7;
}

char *decrypt(PKCS7 *pkcs7, EVP_PKEY *pkey, X509 *cert) {

    BIO *out = BIO_new(BIO_s_mem());
    if (PKCS7_decrypt(pkcs7, pkey, cert, out, 0) != 1) {
        X509_free(cert);
        EVP_PKEY_free(pkey);
        PKCS7_free(pkcs7);
        fprintf(stderr, "Error decrypting PKCS#7 object: %ld\n", ERR_get_error());
        return NULL;
    }
    BUF_MEM* mem;
    BIO_get_mem_ptr(out, &mem);
    char *data = malloc(mem->length + 1);
    memcpy(data, mem->data, mem->length + 1);
    BIO_flush(out);
    BIO_free(out);
    return data;

}

char *decrypt_smime(const char *encrypted, const char *privateKey, const char *certificate) {

    OpenSSL_add_all_algorithms();
    ERR_load_crypto_strings();

    X509 *cert = getCert(certificate);
    if (!cert) {
        return NULL;
    }

    EVP_PKEY *pkey = getKey(privateKey);
    if (!pkey) {
        X509_free(cert);
        return NULL;
    }

    PKCS7 *pkcs7 = getContainer(encrypted);
    if (!pkcs7) {
        X509_free(cert);
        EVP_PKEY_free(pkey);
        return NULL;
    }

    char *data = decrypt(pkcs7, pkey, cert);

    X509_free(cert);
    EVP_PKEY_free(pkey);
    PKCS7_free(pkcs7);

    return data;
}

关于ios - 适用于 iOS 的 S/MIME 电子邮件加密库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43126121/

相关文章:

swift - 在 iOS 中动态更改应用程序语言

c++ - 带有 Boost::Beast 的 SSL 隧道

Java SSL 客户端未选择智能卡 key

ios - 如何唯一识别 iPhone/iPad?

objective-c - 需要有关消耗 RAM 的循环的帮助

ios - `ios` 中常规图像和按钮图像的使用有何不同?

ios - 使用 UICollectionView 的类似磁贴的应用程序

swift - 从协议(protocol)创建对象时,编译器没有引发错误

android - 有没有办法在 Eclipse 中编译 GnuTLS?

ios - 如何在 iOS 中通过 In App Purchase 一次购买多个数量的一种产品