2

古いObjective-Cコードの一部をSwiftに変換しているため、非推奨のメソッドから離れることができますが、クラッシュが発生し続けており、これまでのところ原因がわかりません. P12証明書から秘密鍵を取得していますが、この方法は、実際にCFArrayから辞書を取得する必要がある部分に到達するまでは正常に機能しているようです.配列に値が含まれていても、アプリはクラッシュし続けます. . これが私が持っているコードです:

func privateKeyFromCertificate(p12Name: String, withPassword password: String) -> SecKeyRef {
    let resourcePath: String = NSBundle.mainBundle().pathForResource(p12Name, ofType: "p12")!
    let p12Data: NSData = NSData(contentsOfFile: resourcePath)!
    let key : NSString = kSecImportExportPassphrase as NSString
    let options : NSDictionary = [key : password]

    var privateKeyRef: SecKeyRef? = nil


    var items : CFArray?


    let securityError: OSStatus = SecPKCS12Import(p12Data, options, &items)

    let description : CFString = CFCopyDescription(items)
    print(description)

    if securityError == noErr && CFArrayGetCount(items) > 0 {
        let objects : CFDictionaryRef = CFArrayGetValueAtIndex(items, 0) as! CFDictionaryRef
        let kString : NSString = kSecImportItemIdentity as NSString
        let identity : SecIdentityRef = CFDictionaryGetValue(objects, unsafeAddressOf(kString)) as! SecIdentityRef
        let securityError = SecIdentityCopyPrivateKey(identity, &privateKeyRef)
        if securityError != noErr {
            privateKeyRef = nil
        }
    }
    return privateKeyRef!
}

CFArray から CFDictionaryRef を取得しようとする最初の行の if ステートメントでアプリがクラッシュし続けます。CFArray の説明をテストとして出力する行を追加しましたが、値があります。

<CFArray 0x7fd2d2e8c2f0 [0x10b61f7b0]>{type = mutable-small, count = 1, values = (
0 : <CFBasicHash 0x7fd2d2e8c190 [0x10b61f7b0]>{type = mutable dict, count = 3,entries =>
0 : <CFString 0x10bfdd2c0 [0x10b61f7b0]>{contents = "trust"} = <SecTrustRef: 0x7fd2d2e8ad30>
1 : <CFString 0x10bfdd300 [0x10b61f7b0]>{contents = "identity"} = <SecIdentityRef: 0x7fd2d2e80390>
2 : <CFString 0x10bfdd2e0 [0x10b61f7b0]>{contents = "chain"} = <CFArray 0x7fd2d2d016e0 [0x10b61f7b0]>{type = mutable-small, count = 1, values = (
0 : <cert(0x7fd2d2e8c610) s: Client (IPHONE-WebService) i:Client (IPHONE-WebService)>)}}
4

1 に答える 1

5

データを取得するためにいくつかの変更を加えました。これは最も美しいアプローチではありませんが、私にとってはうまくいきました。

func privateKeyFromCertificate() -> SecKeyRef {
    let certName : String = //name of the certificate//
    //get p12 file path
    let resourcePath: String = NSBundle.mainBundle().pathForResource(certName, ofType: "p12")!
    let p12Data: NSData = NSData(contentsOfFile: resourcePath)!
    //create key dictionary for reading p12 file
    let key : NSString = kSecImportExportPassphrase as NSString
    let options : NSDictionary = [key : "password_for_certificate"]
    //create variable for holding security information
    var privateKeyRef: SecKeyRef? = nil

    var items : CFArray?

    let securityError: OSStatus = SecPKCS12Import(p12Data, options, &items)
    //let description : CFString = CFCopyDescription(items)
    //print(description)

    let theArray : CFArray = items!

    if securityError == noErr && CFArrayGetCount(theArray) > 0 {
        let newArray = theArray as [AnyObject] as NSArray
        let dictionary = newArray.objectAtIndex(0)
        let secIdentity = dictionary.valueForKey(kSecImportItemIdentity as String) as! SecIdentityRef
        let securityError = SecIdentityCopyPrivateKey(secIdentity , &privateKeyRef)
        if securityError != noErr {
            privateKeyRef = nil
        }
    }
    return privateKeyRef!
}
于 2015-10-10T04:47:32.843 に答える