iOS中DES3的加密與解密

最近一個(gè)項(xiàng)目,做注冊(cè)驗(yàn)證碼請(qǐng)求時(shí),需要按照一定規(guī)則生成一個(gè)可解密的token字符串,最后選用了DES3。下面簡(jiǎn)述下DES3在項(xiàng)目中如何使用的。

首先用了一個(gè)Base64的庫(kù)叫GTMBase64,這個(gè)可以去網(wǎng)上下載。
然后下面就是我封裝的一個(gè)工具類(lèi):

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

//加密解密的key,與后臺(tái)一致
#define USER_KEY @"0123456789abcd0123456789"
//初始化向量,與后臺(tái)一致
#define initIv    @"12345678"

@implementation GXDESTools
+ (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)//傳遞過(guò)來(lái)的是decrypt 解碼
    {
        //解碼 base64
        NSData *decryptData = [GTMBase64 decodeData:[sText dataUsingEncoding:NSUTF8StringEncoding]];//轉(zhuǎn)成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函數(shù)加密一下,然后用base64編碼下,傳過(guò)去
     DES解密 :把收到的數(shù)據(jù)根據(jù)base64,decode一下,然后再用CCCrypt函數(shù)解密,得到原本的數(shù)據(jù)
     */
    CCCryptorStatus ccStatus;
    uint8_t *dataOut = NULL; //可以理解位type/typedef 的縮寫(xiě)(有效的維護(hù)了代碼,比如:一個(gè)人用int,一個(gè)人用long。最好用typedef來(lái)定義)
    size_t dataOutAvailable = 0; //size_t  是操作符sizeof返回的結(jié)果類(lèi)型
    size_t dataOutMoved = 0;
    
    dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
    dataOut = malloc( dataOutAvailable * sizeof(uint8_t));
    memset((void *)dataOut, 0x0, dataOutAvailable);//將已開(kāi)辟內(nèi)存空間buffer的首 1 個(gè)字節(jié)的值設(shè)為值 0
    
    const void *vkey = (const void *) [key UTF8String];
    const void *iv = (const void *) [initIv UTF8String];
    
    //CCCrypt函數(shù) 加密/解密
    ccStatus = CCCrypt(encryptOperation,//  加密/解密
                       kCCAlgorithm3DES,//  加密根據(jù)哪個(gè)標(biāo)準(zhǔn)(des,3des,aes。。。。)
                       kCCOptionPKCS7Padding,//  選項(xiàng)分組密碼算法(des:對(duì)每塊分組加一次密  3DES:對(duì)每塊分組加三個(gè)不同的密)
                       vkey,  //密鑰    加密和解密的密鑰必須一致
                       kCCKeySize3DES,//   DES 密鑰的大?。╧CCKeySizeDES=8)
                       iv, //  可選的初始矢量
                       dataIn, // 數(shù)據(jù)的存儲(chǔ)單元
                       dataInLength,// 數(shù)據(jù)的大小
                       (void *)dataOut,// 用于返回?cái)?shù)據(jù)
                       dataOutAvailable,
                       &dataOutMoved);
    
    NSString *result = nil;
    
    if (encryptOperation == kCCDecrypt)//encryptOperation==1  解碼
    {
        //得到解密出來(lái)的data數(shù)據(jù),改變?yōu)閡tf-8的字符串
        result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding] ;
    }
    else //encryptOperation==0  (加密過(guò)程中,把加好密的數(shù)據(jù)轉(zhuǎn)成base64的)
    {
        //編碼 base64
        NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];
        result = [GTMBase64 stringByEncodingData:data];
    }
    
    return result;
}
@end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,979評(píng)論 25 709
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,544評(píng)論 19 139
  • 1.數(shù)據(jù)安全 01數(shù)據(jù)安全的原則1)在網(wǎng)絡(luò)上"不允許"傳輸用戶(hù)隱私數(shù)據(jù)的"明文"2.)在本地"不允許"保存用戶(hù)隱私...
    陳賀閱讀 2,269評(píng)論 0 2
  • 1.數(shù)據(jù)安全 01 攻城利器:Charles(公司中一般都使用該工具來(lái)抓包,并做網(wǎng)絡(luò)測(cè)試) 注意:Charles在...
    Lucky丶晴閱讀 1,604評(píng)論 0 9
  • 自己摸索中的小作品,請(qǐng)多多指教啦
    檸檬汁_824閱讀 186評(píng)論 0 0

友情鏈接更多精彩內(nèi)容