2

我正在从服务器获取一个 p12 文件。我需要在设置应用程序中的设备配置文件中安装该 p12 文件。下面是我的代码

var documentsDirectory: NSURL?
var fileURL: NSURL?

documentsDirectory = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).last! as NSURL
fileURL = documentsDirectory!.appendingPathComponent("AuthRsa.p12")! as NSURL

if (fileURL!.checkResourceIsReachableAndReturnError(nil)) {
     print("file exist")
}else{
     print("file doesn't exist")
     do {
             try p12FileData.write(to: fileURL! as URL)
        } catch {
             print(error)
        }
}
print(fileURL!)
let p12Data: NSData = NSData(contentsOfFile: fileURL!.path!)!
let key : NSString = kSecImportExportPassphrase as NSString
let options : NSDictionary = [key : "test"]

var rawItems : CFArray?

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

let items = rawItems! as! Array<Dictionary<String, Any>>
let firstItem = items[0]
let identity = firstItem[kSecImportItemIdentity as String] as! SecIdentity?
let trust = firstItem[kSecImportItemTrust as String] as! SecTrust?

let ptr = p12Data.bytes.assumingMemoryBound(to: UInt8.self)

let cfData = CFDataCreate(kCFAllocatorDefault, ptr, p12Data.length)
let cert:SecCertificate? = SecCertificateCreateWithData(kCFAllocatorDefault, cfData!)
print(cert!)
let addquery: [String: Any] = [kSecClass as String: kSecClassCertificate, kSecValueRef as String: certificate!, kSecAttrLabel as String: "My Certificate"]         
let status = SecItemAdd(addquery as CFDictionary, nil)
print(status)

我在 print(cert!) 行出现“意外发现 nil 值”崩溃,因为证书无法生成。

所以你能帮帮我吗?

提前致谢。

4

0 回答 0