Wie kann ich SecKeyRef aus DER / PEM-Datei erhalten

Ich muss meine iPhone-App in ein System integrieren und sie muss Daten mit einem bestimmten öffentlichen Schlüssel verschlüsseln. Es gibt 3 Dateien in 3 verschiedenen Formaten .xml .der und .pem. Ich habe einige Artikel zum Abrufen von SecKeyRef recherchiert und gefunden DER / PEM, aber sie sind immer null zurück. Unten ist mein Code:

<code>NSString *pkFilePath = [[NSBundle mainBundle] pathForResource:@"PKFile" ofType:@"der"];
NSData *pkData = [NSData dataWithContentsOfFile:pkFilePath]; 

SecCertificateRef   cert; 
cert = SecCertificateCreateWithData(NULL, (CFDataRef) pkData);
assert(cert != NULL);

OSStatus err;

    if (cert != NULL) {
        err = SecItemAdd(
                         (CFDictionaryRef) [NSDictionary dictionaryWithObjectsAndKeys:
                                            (id) kSecClassCertificate,  kSecClass, 
                                            (id) cert,                  kSecValueRef,
                                            nil
                                            ], 
                         NULL
                         );
        if ( (err == errSecSuccess) || (err == errSecDuplicateItem) ) {
            CFArrayRef certs = CFArrayCreate(kCFAllocatorDefault, (const void **) &cert, 1, NULL); 
            SecPolicyRef policy = SecPolicyCreateBasicX509();
            SecTrustRef trust;
            SecTrustCreateWithCertificates(certs, policy, &trust);
            SecTrustResultType trustResult;
            SecTrustEvaluate(trust, &trustResult);
            if (certs) {
                CFRelease(certs);
            }
            if (trust) {
                CFRelease(trust);
            }
            return SecTrustCopyPublicKey(trust);
        }
    }
return NULL;
</code>

Das Problem tritt bei SecCertificateCreateWithData auf, es wird immer nil zurückgegeben, auch wenn die gelesene Datei in Ordnung ist. Jeder hat das getan, bitte helfen Sie mir, danke!

BEARBEITEN: Die Zertifizierungsdatei war eine MD5-Signatur.

Antworten auf die Frage(3)

Ihre Antwort auf die Frage