iOS的MD5/SHA1加密算法的實現(xiàn)

HASH算法是密碼學(xué)的基礎(chǔ),比較常用的有MD5和SHA,最重要的兩條性質(zhì),就是不可逆和無沖突
所謂不可逆,就是當你知道x的HASH值,無法求出x;
所謂無沖突,就是當你知道x,無法求出一個y, 使x與y的HASH值相同。
這兩條性質(zhì)在數(shù)學(xué)上都是不成立的。因為一個函數(shù)必然可逆,且由于HASH函數(shù)的值域有限,理論上會有無窮多個不同的原始值,它們的hash值都相同。MD5和SHA做到的,是求逆和求沖突在計算上不可能,也就是正向計算很容易,而反向計算即使窮盡人類所有的計算資源都做不到。

廢話說到這,這里我們看在iOS中MD5/SHA1是怎樣實現(xiàn)的

GTMVase64&下載地址: https://code.google.com/p/google-toolbox-for-mac/source/browse/trunk/Foundation/?r=87

說明:Base64不是用來加密的。你看看經(jīng)過BASE64編碼后的字符串,全部都是由標準鍵盤上面的常規(guī)字符組成,這樣編碼后的字符串在網(wǎng)關(guān)之間傳遞不會產(chǎn)生UNICODE字符串不能識別或者丟失的現(xiàn)象。你再仔細研究下EMAIL就會發(fā)現(xiàn)其實EMAIL就是用base64編碼過后再發(fā)送的。然后接收的時候再還原。 有一種情況下用Base64編碼也很好,比如一個圖片文件,或者其他任何二進制文件。我可以把它編碼成字符串。這樣用XML或者數(shù)據(jù)庫就能直接以文本的方式來存儲這些文件了

要引入#import <CommonCrypto/CommonDigest.h>

SHA1編碼

- (NSString*) sha1
{
    const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];

    NSData *data = [NSData dataWithBytes:cstr length:self.length];
    //使用對應(yīng)的CC_SHA1,CC_SHA256,CC_SHA384,CC_SHA512的長度分別是20,32,48,64
    uint8_t digest[CC_SHA1_DIGEST_LENGTH];
    //使用對應(yīng)的CC_SHA256,CC_SHA384,CC_SHA512
    CC_SHA1(data.bytes, data.length, digest);
    
    NSMutableString* output = [NSMutableString stringWithCapacity:CC_SHA1_DIGEST_LENGTH * 2];
    
    for(int i = 0; i < CC_SHA1_DIGEST_LENGTH; i++)
        [output appendFormat:@"%02x", digest[i]];
    
    return output;
}


MD5編碼

-(NSString *) md5
{
    const char *cStr = [self UTF8String];
    unsigned char digest[CC_MD5_DIGEST_LENGTH];
    CC_MD5( cStr, strlen(cStr), digest );
    
    NSMutableString *output = [NSMutableString stringWithCapacity:CC_MD5_DIGEST_LENGTH * 2];
    
    for(int i = 0; i < CC_MD5_DIGEST_LENGTH; i++)
        [output appendFormat:@"%02x", digest[i]];
    
    return output;
}

當然也可以結(jié)合BASE64來使用,這里的BASE64編碼使用 GTMBase64實現(xiàn)
我們要引入了一個GTMBase64編碼解碼字符串,下載地址在前面!

- (NSString *) sha1_base64
{
    const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
    NSData *data = [NSData dataWithBytes:cstr length:self.length];
    
    uint8_t digest[CC_SHA1_DIGEST_LENGTH];
    
    CC_SHA1(data.bytes, data.length, digest);
    
    NSData * base64 = [[NSData alloc]initWithBytes:digest length:CC_SHA1_DIGEST_LENGTH];
    base64 = [GTMBase64 encodeData:base64];
    
    NSString * output = [[NSString alloc] initWithData:base64 encoding:NSUTF8StringEncoding];
    return output;
}

- (NSString *) md5_base64
{
    const char *cStr = [self UTF8String];
    unsigned char digest[CC_MD5_DIGEST_LENGTH];
    CC_MD5( cStr, strlen(cStr), digest );
    
    NSData * base64 = [[NSData alloc]initWithBytes:digest length:CC_MD5_DIGEST_LENGTH];
    base64 = [GTMBase64 encodeData:base64];
    
    NSString * output = [[NSString alloc] initWithData:base64 encoding:NSUTF8StringEncoding];
    return output;
}

- (NSString *) base64
{
    NSData * data = [self dataUsingEncoding:NSASCIIStringEncoding allowLossyConversion:YES];
    data = [GTMBase64 encodeData:data];
    NSString * output = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
    return output; 
}

接下來我們來調(diào)用看一下

NSString *msg = @"123456789";
    NSLog(@"base64加密:%@",[msg base64]);
    NSLog(@"SHA1:%@",[msg sha1]);
    NSLog(@"SHA1_base64加密:%@",[msg sha1_base64]);
    NSLog(@"MD5_base64加密:%@",[msg md5_bas


#輸出結(jié)果
2015-12-26 11:19:19.253 HASH散列算法[1132:153612] base64加密:MTIzNDU2Nzg5
2015-12-26 11:19:19.253 HASH散列算法[1132:153612] SHA1:f7c3bc1d808e04732adf679965ccc34ca7ae3441
2015-12-26 11:19:19.253 HASH散列算法[1132:153612] SHA1_base64加密:98O8HYCOBHMq32eZZczDTKeuNEE=
2015-12-26 11:19:19.253 HASH散列算法[1132:153612] MD5_base64加密:JfnnlDI7RTiF9RgfG2JNCw==
2015-12-26 11:19:19.253 HASH散列算法[1132:153612] MD5加密:25f9e794323b453885f5181f1b624d0b




最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

  • 概述 之前一直對加密相關(guān)的算法知之甚少,只知道類似DES、RSA等加密算法能對數(shù)據(jù)傳輸進行加密,且各種加密算法各有...
    Henryzhu閱讀 3,055評論 0 14
  • 1.數(shù)據(jù)安全 01數(shù)據(jù)安全的原則1)在網(wǎng)絡(luò)上"不允許"傳輸用戶隱私數(shù)據(jù)的"明文"2.)在本地"不允許"保存用戶隱私...
    陳賀閱讀 2,192評論 0 2
  • 這篇文章主要講述在Mobile BI(移動商務(wù)智能)開發(fā)過程中,在網(wǎng)絡(luò)通信、數(shù)據(jù)存儲、登錄驗證這幾個方面涉及的加密...
    雨_樹閱讀 2,701評論 0 6
  • 今天上午11點半看書(世界是平的)看一小時,下午繼續(xù)看了2小時,今天看了60頁面,作者把他的人生方向指示方向為世界...
    周秀峰閱讀 195評論 0 0
  • 你有沒有注意過,自己平時怎么向周邊的朋友介紹一本書? “前幾天我看了一本XX書,真是與眾不同,可好看了”“有一本書...
    李曉峰Jeffrey閱讀 17,006評論 0 9