afn 使用https

苹果最近出台新规,从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;

}

你可能感兴趣的:(afn 使用https)