/*
AES加密解密中用到的指针知识——ios,看(1)、(2)、(3)、(4)、(5)
*/
NSData
* cipherOperation(
NSData
*contentData,
NSData
*keyData,
CCOperation
operation) {
/*
void的字面意思是“无类型”,void *则为“无类型指针”,void *可以指向任何类型的数据。const之后的值,对应着常量
*/
void
const
*initVectorBytes = [
kInitVector
dataUsingEncoding
:
NSUTF8StringEncoding
].
bytes
;
void
const
*contentBytes = contentData.
bytes
;
void
const
*keyBytes = keyData.
bytes
;
NSUInteger
dataLength = contentData.
length
;
//本身长度 +为了防止最后一个明(密)文块不完整,所以加上16bytes
size_t
operationSize = dataLength +
kCCBlockSizeAES128
;
//(1)内存自动分配函数,最后得到的是一个自动分配的存储区,operationBytes是地址,此存储区的初始内容不确定,如果失败返回NULL
void
*operationBytes =
malloc
(operationSize);
if
(operationBytes ==
NULL
) {
return
nil
;
}
//初始化输出尺寸
size_t
actualOutSize =
0
;
//(2)我们传入的指针变量
operationBytes
实际上对应的是存储区的地址,当然我们要在加密方法中,在地址中放入密文块或者名文块,方便后期获取,返回值是一个状态
//(3)把actualOutSize取地址放到函数内,在函数中对地址中对应的数字进行操作,最后我们得到的是输出时候的长度
CCCryptorStatus
cryptStatus =
CCCrypt
(operation,
kCCAlgorithmAES
,
kCCOptionPKCS7Padding
,
keyBytes,
kKeySize
,
initVectorBytes
,
contentBytes,
dataLength,
operationBytes,
operationSize,
&actualOutSize
);
//如果判断状态是成功的话
if
(cryptStatus ==
kCCSuccess
) {
//(4)
从一个给定的给定字节数的存储区地址,创建并返回一个数据对象。从存储区地址获取存储区内容,内容在
CCCrypt
方法中已经放好了 operationBytes本身是一个地址
return
[
NSData
dataWithBytesNoCopy
:operationBytes
length
:actualOutSize];
}
//(5)malloc()函数自动分配内存,最后是一定要释放的
free
(operationBytes);
operationBytes =
NULL
;
return
nil
;
}