我正在从服务器获取一个 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 值”崩溃,因为证书无法生成。
所以你能帮帮我吗?
提前致谢。