苹果最近出台新规,从2017年1月1日起,iOS 就告别http了,下边是afn使用https的一些步骤.
1.crt 证书转cer
openssl x509 -in �证书名.crt -out 证书名.cer -outform der
2.
AFHTTPRequestOperationManager*manager = [AFHTTPRequestOperationManagermanager];
//申明返回的结果是json类型
manager.responseSerializer= [AFJSONResponseSerializerserializer];
//申明请求的数据是json类型
manager.requestSerializer=[AFJSONRequestSerializerserializer];
manager.responseSerializer.acceptableContentTypes= [NSSetsetWithObjects:@"text/html",@"text/plain",@"application/json",nil];
[manager.securityPolicysetAllowInvalidCertificates:YES];
[managersetSecurityPolicy:[selfcustomSecurityPolicy]];
+ (AFSecurityPolicy*)customSecurityPolicy
{
// /先导入证书
NSString*cerPath = [[NSBundlemainBundle]pathForResource:@"meng"ofType:@"cer"];//证书的路径
NSData*certData = [NSDatadataWithContentsOfFile:cerPath];
//NSLog(@"===%@",certData);
// AFSSLPinningModeCertificate使用证书验证模式
AFSecurityPolicy*securityPolicy = [AFSecurityPolicydefaultPolicy];
// allowInvalidCertificates是否允许无效证书(也就是自建的证书),默认为NO
//如果是需要验证自建证书,需要设置为YES
securityPolicy.allowInvalidCertificates=YES;
//validatesDomainName是否需要验证域名,默认为YES;
//假如证书的域名与你请求的域名不一致,需把该项设置为NO;如设成NO的话,即服务器使用其他可信任机构颁发的证书,也可以建立连接,这个非常危险,建议打开。
//置为NO,主要用于这种情况:客户端请求的是子域名,而证书上的是另外一个域名。因为SSL证书上的域名是独立的,假如证书上注册的域名是www.google.com,那么mail.google.com是无法验证通过的;当然,有钱可以注册通配符的域名*.google.com,但这个还是比较贵的。
//如置为NO,建议自己添加对应域名的校验逻辑。
securityPolicy.validatesDomainName=NO;
securityPolicy.pinnedCertificates=@[certData];
returnsecurityPolicy;
}