使用原生的NSURLSession請求時獲取https遠程證書的sha256

參考文章 iOS獲取SSL證書的sha1值和sha256值 感謝作者!

首先我們可以通過瀏覽器查看遠程https的sha256或者sha1

通過瀏覽器查看證書1.png
通過瀏覽器查看證書2.png
通過瀏覽器查看證書3.png

通過代碼獲取方法如下

初始化NSURLSession對象時指定代理

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

實現(xiàn)如下代理方法

- (void)URLSession:(NSURLSession *)session didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition disposition, NSURLCredential * _Nullable credential))completionHandler
{
    SecTrustRef serverTrust = [[challenge protectionSpace] serverTrust];
//這里取第一個值的論證,其實我沒找到,只是查到的都是取第一個值.如果有看到取第一個值的文獻,麻煩推薦一下.
    SecCertificateRef certRef = SecTrustGetCertificateAtIndex(serverTrust, 0);
    //        CFStringRef certSummary = SecCertificateCopySubjectSummary(certRef);
    CFDataRef certData = SecCertificateCopyData(certRef);
//此處CFDataRef可直接強轉(zhuǎn)NSData類型
    NSData *myData = (__bridge NSData *)certData;
    NSString *sha256 =  [self sha256:myData];
    NSLog(@"sha256=%@\n ---- certificateNo=%@",sha256,[YZTLoanDoor share].certificateNo);
    BOOL result = [sha256 compare:remoteCerSha256 options:NSCaseInsensitiveSearch];(忽略大小寫的字符串對比)
    if (result == NSOrderedSame) {
        NSURLCredential *card = [[NSURLCredential alloc]initWithTrust:challenge.protectionSpace.serverTrust];
        completionHandler(NSURLSessionAuthChallengeUseCredential , card);
    } else {
        NSURLCredential *card = [[NSURLCredential alloc]initWithTrust:challenge.protectionSpace.serverTrust];
        completionHandler(NSURLSessionAuthChallengeCancelAuthenticationChallenge , card);
    }
}

引入頭文件

#import <CommonCrypto/CommonDigest.h>

實現(xiàn)方法

- (NSString*)sha256:(NSData*)certData
{
    unsigned char sha256Buffer[CC_SHA256_DIGEST_LENGTH];
    CC_SHA256(certData.bytes, certData.length, sha256Buffer);
    NSMutableString *fingerprint = [NSMutableString stringWithCapacity:CC_SHA256_DIGEST_LENGTH * 3];
    for (int i = 0; i < CC_SHA256_DIGEST_LENGTH; ++i)
        [fingerprint appendFormat:@"%02x",sha256Buffer[i]];
    return [fingerprint stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
}

當(dāng)然如果需要sha1,使用一下方法

+(NSString*)sha1:(NSData*)certData {
    unsigned char sha1Buffer[CC_SHA1_DIGEST_LENGTH];
    CC_SHA1(certData.bytes, certData.length, sha1Buffer);
    NSMutableString *fingerprint = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 3];
    for (int i = 0; i < CC_SHA1_DIGEST_LENGTH; ++i)
        [fingerprint appendFormat:@"%02x ",sha1Buffer[i]];
    return [fingerprint stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市菲驴,隨后出現(xiàn)的幾起案子荐吵,更是在濱河造成了極大的恐慌,老刑警劉巖赊瞬,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件先煎,死亡現(xiàn)場離奇詭異,居然都是意外死亡巧涧,警方通過查閱死者的電腦和手機薯蝎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谤绳,“玉大人占锯,你說我怎么就攤上這事∷跎福” “怎么了消略?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長瞎抛。 經(jīng)常有香客問我艺演,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任胎撤,我火速辦了婚禮晓殊,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘哩照。我一直安慰自己,他們只是感情好懒浮,可當(dāng)我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布飘弧。 她就那樣靜靜地躺著,像睡著了一般砚著。 火紅的嫁衣襯著肌膚如雪次伶。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天稽穆,我揣著相機與錄音冠王,去河邊找鬼。 笑死舌镶,一個胖子當(dāng)著我的面吹牛柱彻,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播餐胀,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼哟楷,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了否灾?” 一聲冷哼從身側(cè)響起卖擅,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎墨技,沒想到半個月后惩阶,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡扣汪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年断楷,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片崭别。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡脐嫂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出紊遵,到底是詐尸還是另有隱情账千,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布暗膜,位于F島的核電站匀奏,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏学搜。R本人自食惡果不足惜娃善,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一论衍、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧聚磺,春花似錦坯台、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至焕阿,卻和暖如春咪啡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背暮屡。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工撤摸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人褒纲。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓准夷,卻偏偏與公主長得像,于是被迫代替她去往敵國和親莺掠。 傳聞我的和親對象是個殘疾皇子冕象,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,834評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時...
    歐辰_OSR閱讀 29,321評論 8 265
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)汁蝶,斷路器渐扮,智...
    卡卡羅2017閱讀 134,600評論 18 139
  • js數(shù)組有4種聲明和定義的方式,主要分為構(gòu)造函數(shù)聲明掖棉、字面量聲明墓律。數(shù)組的應(yīng)用是非常廣的,巧妙的應(yīng)用數(shù)組是體現(xiàn)...
    月光在心中閱讀 197評論 0 1
  • 前言 1幔亥、Flutter是Google使用Dart語言開發(fā)的移動應(yīng)用開發(fā)框架耻讽,使用一套Dart代碼就能構(gòu)建高性能、...
    霧里看花六月天閱讀 346評論 0 1
  • 分享一個在GitHub上面下載開源項目后帕棉,安裝在Mac上方法 1.打開項目针肥,編譯(Command+B)項目 ,打開...
    vvkeep閱讀 3,712評論 12 57