码迷,mamicode.com
首页 > Web开发 > 详细

NSURLSession http转Https

时间:2018-01-03 13:50:25      阅读:197      评论:0      收藏:0      [点我收藏+]

标签:methods   getc   col   安全   sso   span   pat   pos   file   

1.设置代理

NSURLSession *sesson = [NSURLSession sessionWithConfiguration:[NSURLSessionConfiguration defaultSessionConfiguration] delegate:self delegateQueue:[[NSOperationQueue alloc]init]];

2.在代理方法中实现对证书的操作 


方法一:这是在开发者足够信任后端的安全的情况下做的,比如调个接口,这样做的结果就是忽略证书的验证,直接信任。

- (void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition, NSURLCredential * _Nullable))completionHandler{

    if([challenge.protectionSpace.authenticationMethod isEqualToString:NSURLAuthenticationMethodServerTrust]){//服务器信任证书

        

        NSURLCredential *credential = [NSURLCredential credentialForTrust:challenge.protectionSpace.serverTrust];//服务器信任证书

        if(completionHandler)

        completionHandler(NSURLSessionAuthChallengeUseCredential,credential);

    }

}

 

方法二:可以把证书加到工程中,然后https访问时在代理方法中进行证书的验证

 

- (void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition, NSURLCredential * _Nullable))completionHandler{

    

    SecTrustRef servertrust = challenge.protectionSpace.serverTrust;

    SecCertificateRef certi= SecTrustGetCertificateAtIndex(servertrust, 0);

    NSData *certidata = CFBridgingRelease(CFBridgingRetain(CFBridgingRelease(SecCertificateCopyData(certi))));

    NSString *path = [[NSBundle mainBundle] pathForResource:@"https" ofType:@"cer"];

    NSData *localCertiData = [NSData dataWithContentsOfFile:path];

    if ([certidata isEqualToData:localCertiData]) {

        NSURLCredential *credential = [[NSURLCredential alloc] initWithTrust:servertrust];

        [challenge.sender useCredential:credential forAuthenticationChallenge:challenge];

        completionHandler(NSURLSessionAuthChallengeUseCredential, credential);

        NSLog(@"服务端证书认证通过");

    }else {

        completionHandler(NSURLSessionAuthChallengeCancelAuthenticationChallenge, nil);

        NSLog(@"服务端认证失败");

    }

    

}

NSURLSession http转Https

标签:methods   getc   col   安全   sso   span   pat   pos   file   

原文地址:https://www.cnblogs.com/huangzs/p/8183089.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!