傻瓜式教學DES加密、解密

weixin_33976072發表於2017-05-12

廢話不說,直接說步驟

1.

先下載GTMBase64檔案,把這個檔案拖入到專案中,檔案在DESDemo裡,可直接下載。

2.

新建DESEncrypt類,繼承於NSObject,

DESEncrypt.h中

寫加密解密方法,其中sText引數就是要加密和解密的字串

// 加密方法
+ (NSString *)encryptWithText:(NSString *)sText;

// 解密方法
+ (NSString *)decryptWithText:(NSString *)sText;
DESEncrypt.m中

先匯入

#import <CommonCrypto/CommonCrypto.h>
#import "GTMBase64.h"
#import "GTMDefines.h"

再定義key 和偏移量

//加密解密的key,與後臺一致
#define USER_KEY @"12345678"
//初始化向量,與後臺一致
#define initIv    @"12345678"

然後實現加密解密方法

+ (NSString *)encryptWithText:(NSString *)sText
{
    //kCCEncrypt 加密
    return [self encrypt:sText encryptOrDecrypt:kCCEncrypt key:USER_KEY];
}

+ (NSString *)decryptWithText:(NSString *)sText
{
    //kCCDecrypt 解密
    return [self encrypt:sText encryptOrDecrypt:kCCDecrypt key:USER_KEY];
}

+ (NSString *)encrypt:(NSString *)sText encryptOrDecrypt:(CCOperation)encryptOperation key:(NSString *)key
{
    const void *dataIn;
    size_t dataInLength;
    
    if (encryptOperation == kCCDecrypt)//傳遞過來的是decrypt 解碼
    {
        //解碼 base64
        NSData *decryptData = [GTMBase64 decodeData:[sText dataUsingEncoding:NSUTF8StringEncoding]];//轉成utf-8並decode
        dataInLength = [decryptData length];
        dataIn = [decryptData bytes];
    }
    else  //encrypt
    {
        NSData* encryptData = [sText dataUsingEncoding:NSUTF8StringEncoding];
        dataInLength = [encryptData length];
        dataIn = (const void *)[encryptData bytes];
    }
    
    /*
     DES加密 :用CCCrypt函式加密一下,然後用base64編碼下,傳過去
     DES解密 :把收到的資料根據base64,decode一下,然後再用CCCrypt函式解密,得到原本的資料
     */
    CCCryptorStatus ccStatus;
    uint8_t *dataOut = NULL; //可以理解位type/typedef 的縮寫(有效的維護了程式碼,比如:一個人用int,一個人用long。最好用typedef來定義)
    size_t dataOutAvailable = 0; //size_t  是操作符sizeof返回的結果型別
    size_t dataOutMoved = 0;
    
    dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
    dataOut = malloc( dataOutAvailable * sizeof(uint8_t));
    memset((void *)dataOut, 0x0, dataOutAvailable);//將已開闢記憶體空間buffer的首 1 個位元組的值設為值 0
    
    const void *vkey = (const void *) [key UTF8String];
    const void *iv = (const void *) [initIv UTF8String];
    
    //CCCrypt函式 加密/解密
    ccStatus = CCCrypt(encryptOperation,//  加密/解密
                       kCCAlgorithmDES,//  加密根據哪個標準(des,3des,aes。。。。)
                       kCCOptionPKCS7Padding,//選項分組密碼演算法(des:對每塊分組加一次密  3DES:對每塊分組加三個不同的密)
                       vkey,  //金鑰    加密和解密的金鑰必須一致
                       kCCKeySizeDES,//   DES 金鑰的大小(kCCKeySizeDES=8)
                       iv, //  可選的初始向量
                       dataIn, // 資料的儲存單元
                       dataInLength,// 資料的大小
                       (void *)dataOut,// 用於返回資料
                       dataOutAvailable,
                       &dataOutMoved);
    NSString *result = nil;
    
    if (encryptOperation == kCCDecrypt)//encryptOperation==1  解碼
    {
        //得到解密出來的data資料,改變為utf-8的字串
        result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding] ;
    }
    else //encryptOperation==0  (加密過程中,把加好密的資料轉成base64的)
    {
        //編碼 base64
        NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];
        result = [GTMBase64 stringByEncodingData:data];
    }
    
    return result;
}
完成
3.使用

在將要加密和解密的地方呼叫加密解密方法
例如:

NSString *str1 = @"測試測試測試";
NSString *encryptStr = [DESEncrypt encryptWithText:str1];    // 加密
NSLog(@"加密後 %@",encryptStr);
NSString *decryptStr = [DESEncrypt decryptWithText:encryptStr];  // 解密
NSLog(@"解密後 %@",decryptStr);

列印結果:

2017-05-12 11:11:37.627 DESDemo[20609:1419932] 原字串 測試測試測試
2017-05-12 11:11:37.628 DESDemo[20609:1419932] 加密後 fNsINOSE6xoSz/AtptTlcMoUMv+4nSgr
2017-05-12 11:11:37.628 DESDemo[20609:1419932] 解密後 測試測試測試

相關文章