iOS下的加密

二話不說缤至,先上Demohttps://github.com/haidumou/CZHEncryption

RSA加密

RSA使用"秘匙對"對數(shù)據(jù)進(jìn)行加密解密.在加密解密數(shù)據(jù)前,需要先生成公鑰(public key)和私鑰(private key).

  • 公鑰(public key): 用于加密數(shù)據(jù). 用于公開, 一般存放在數(shù)據(jù)提供方, 例如iOS客戶端.
  • 私鑰(private key): 用于解密數(shù)據(jù). 必須保密, 私鑰泄露會造成安全問題.

iOS中的Security.framework提供了對RSA算法的支持.這種方式需要對密匙對進(jìn)行處理, 根據(jù)public key生成證書, 通過private key生成p12格式的密匙.除了Secruty.framework, 也可以將openssl庫編譯到iOS工程中, 這可以提供更靈活的使用方式.
本文使用Security.framework的方式處理RSA.

RSA加密需要了解的幾點:

  • 公鑰加密,私鑰解密且蓬。加密的系統(tǒng)和解密的系統(tǒng)分開部署蜡娶,加密的系統(tǒng)不應(yīng)該同時具備解密的功能
  • 生成密文的長度等于密鑰長度混卵。密鑰長度越大,生成密文的長度也就越大窖张,加密的速度也就越慢幕随,而密文也就越難被破解掉。
  • 生成密文的長度和明文長度無關(guān)宿接,但明文長度不能超過密鑰長度赘淮。不管明文長度是多少辕录,RSA 生成的密文長度總是固定的。但是明文長度不能超過密鑰長度梢卸。
  • 在iOS中使用RSA加密解密走诞,需要用到.der和.p12后綴格式的文件,其中.der格式的文件存放的是公鑰(Public key)用于加密蛤高,.p12格式的文件存放的是私鑰(Private key)用于解密

DES加解密

const Byte iv[] = {1,2,3,4,5,6,7,8};
/*加密/
+ (NSString *)DESEncrypt:(NSString *)plainText key:(NSString *)key
{
NSString *ciphertext = nil;
NSData *textData = [plainText dataUsingEncoding:NSUTF8StringEncoding];
NSUInteger dataLength = [textData length];
size_t bufferSize = dataLength + kCCBlockSizeDES;
void *buffer = malloc(bufferSize);
memset(buffer, 0, sizeof(char));
size_t numBytesEncrypted = 0;
CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
kCCOptionPKCS7Padding,
[key UTF8String], kCCKeySizeDES,
iv,
[textData bytes], dataLength,
buffer, bufferSize,
&numBytesEncrypted);
if (cryptStatus == kCCSuccess) {
NSData *data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesEncrypted];
ciphertext = [data base64EncodedString];
}
return ciphertext;
}

  • /**解密*/
    + (NSString *)DESDecrypt:(NSString *)cipherText key:(NSString *)key
    {
        NSString *plaintext = nil;
        NSData *cipherdata = [cipherText base64DecodedData];
        NSUInteger dataLength = [cipherdata length];
        size_t bufferSize = dataLength + kCCBlockSizeDES;
        void *buffer = malloc(bufferSize);
        memset(buffer, 0, sizeof(char));
        size_t numBytesDecrypted = 0;
        CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmDES,
                                        kCCOptionPKCS7Padding,
                                        [key UTF8String], kCCKeySizeDES,
                                        iv,
                                        [cipherdata bytes], dataLength,
                                        buffer, bufferSize,
                                        &numBytesDecrypted);
        if(cryptStatus == kCCSuccess) {
            NSData *plaindata = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
            plaintext = [[NSString alloc]initWithData:plaindata encoding:NSUTF8StringEncoding];
        }
        return plaintext;
    }
    

AES加解密

  /**加密*/
  - (NSString *)AES256Encrypt:(NSString *)key
  {
      const char *cstr = [self cStringUsingEncoding:NSUTF8StringEncoding];
      NSData *data = [NSData dataWithBytes:cstr length:self.length];
      //對數(shù)據(jù)進(jìn)行加密
      NSData *result = [data AES256Encrypt:key];

      //轉(zhuǎn)換為2進(jìn)制字符串
      if (result && result.length > 0) {
         Byte *datas = (Byte*)[result bytes];
          NSMutableString *output = [NSMutableString stringWithCapacity:result.length * 2];
          for(int i = 0; i < result.length; i++){
              [output appendFormat:@"%02x", datas[i]];
          }
          return output;
      }
      return nil;
  }
  • /**解密*/
    - (NSString *)AES256Decrypt:(NSString *)key
    {
        //轉(zhuǎn)換為2進(jìn)制Data
        NSMutableData *data = [NSMutableData dataWithCapacity:self.length / 2];
        unsigned char whole_byte;
        char byte_chars[3] = {'\0','\0','\0'};
        int i;
        for (i = 0; i < [self length] / 2; i++) {
            byte_chars[0] = [self characterAtIndex:i*2];
            byte_chars[1] = [self characterAtIndex:i*2+1];
            whole_byte = strtol(byte_chars, NULL, 16);
            [data appendBytes:&whole_byte length:1];
        }
    
        //對數(shù)據(jù)進(jìn)行解密
        NSData* result = [data AES256Decrypt:key];
        if (result && result.length > 0) {
            return [[NSString alloc] initWithData:result encoding:NSUTF8StringEncoding];
        }
        return nil;
    }
    

MD5加密

  - (NSString *)stringToMD5
  {
      const char *fooData = [self UTF8String];
      unsigned char result[CC_MD5_DIGEST_LENGTH];
      //計算MD5的值, 這是官方封裝好的加密方法:把我們輸入的字符串轉(zhuǎn)換成16進(jìn)制的32位數(shù),然后存儲到result中
      CC_MD5(fooData, (CC_LONG)strlen(fooData), result);
      /**
       第一個參數(shù):要加密的字符串
       第二個參數(shù): 獲取要加密字符串的長度
       第三個參數(shù): 接收結(jié)果的數(shù)組
       */

      NSMutableString *saveResult = [NSMutableString string];
      for (int i = 0; i < CC_MD5_DIGEST_LENGTH; i++) {
          [saveResult appendFormat:@"%02x", result[i]];
      }
      /*
       x表示十六進(jìn)制蚣旱,%02X  意思是不足兩位將用0補(bǔ)齊,如果多余兩位則不影響
        NSLog("%02X", 0x888);  //888
       NSLog("%02X", 0x4); //04
       */
      return saveResult;
  }
屏幕快照 2016-12-06 下午5.22.14.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末戴陡,一起剝皮案震驚了整個濱河市塞绿,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌恤批,老刑警劉巖异吻,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異喜庞,居然都是意外死亡诀浪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進(jìn)店門延都,熙熙樓的掌柜王于貴愁眉苦臉地迎上來雷猪,“玉大人,你說我怎么就攤上這事窄潭。” “怎么了酵颁?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵嫉你,是天一觀的道長。 經(jīng)常有香客問我躏惋,道長幽污,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任簿姨,我火速辦了婚禮距误,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘扁位。我一直安慰自己准潭,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布域仇。 她就那樣靜靜地躺著刑然,像睡著了一般。 火紅的嫁衣襯著肌膚如雪暇务。 梳的紋絲不亂的頭發(fā)上泼掠,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天怔软,我揣著相機(jī)與錄音,去河邊找鬼择镇。 笑死挡逼,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的腻豌。 我是一名探鬼主播家坎,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼饲梭,長吁一口氣:“原來是場噩夢啊……” “哼乘盖!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起憔涉,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤订框,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后兜叨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體穿扳,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年国旷,在試婚紗的時候發(fā)現(xiàn)自己被綠了矛物。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡跪但,死狀恐怖履羞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情屡久,我是刑警寧澤忆首,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站被环,受9級特大地震影響糙及,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜筛欢,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一浸锨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧版姑,春花似錦柱搜、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春宇姚,著一層夾襖步出監(jiān)牢的瞬間匈庭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工浑劳, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留阱持,地道東北人。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓魔熏,卻偏偏與公主長得像衷咽,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蒜绽,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,792評論 2 345

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