廢話不說,直接說步驟
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] 解密后 測試測試測試
- 最后再附上demo地址 DESDemo