How to trust an untrusted Certificate Authority in an iOS 3 application
Issue
iOS 3 has a limited number of Trusted Root Certificate Authorities as detailed here:
http://support.apple.com/kb/HT3580
It is possible to install additional Trusted Root Certificate Authorities using the iPhone Configuration Utility, however this will only affect the Safari web browser, and not calls done from within an application such as NSURLConnection sendSynchronousRequest.
The other issue is that Intermediate Certificate Authorities are not supported.
Resolution
The root or intermediate certificate must be trusted from within the application:
float version = [[[UIDevice currentDevice] systemVersion] floatValue];
if (version < 4) {
// iPhone 3.0 code here
NSString * path;
NSData * data;
SecCertificateRef cert;
path = [[NSBundle mainBundle] pathForResource:@"GeoTrustDVSSLCA" ofType:@"cer"];
data = [NSData dataWithContentsOfFile:path];
cert = SecCertificateCreateWithData(NULL, (CFDataRef) data);
SecItemAdd((CFDictionaryRef) [NSDictionary dictionaryWithObjectsAndKeys:(id) kSecClassCertificate, kSecClass, cert, kSecValueRef, nil], NULL);
CFRelease(cert);
}
References
Products
Apple iOS 3.1.3
Created: 7th January 2012
Updated: 7th January 2012
© 2005-2025 Jamie Morrison