使用 Apple Dev 库 (https://developer.apple.com/library/prerelease/ios/samplecode/CryptoExercise/Listings/Classes_SecKeyWrapper_m.html) 中的示例,
特别是这种方法
- (NSData *)doCipherNSData *)plainText keyNSData *)symmetricKey contextCCOperation)encryptOrDecrypt paddingCCOptions *)pkcs7 { return nil; }
我可以通过将文件读取到 NSData 然后传递给这个方法来解密和加密文件。
但是,不幸的是,我不得不为此过程使用大量 RAM。
有没有办法直接在磁盘上解密文件而不将文件加载到 NSData?
Best Answer-推荐答案 strong>
您可以使用单独的 Common Crypto 例程:CCCrytorCreate() 、CCCryptorUpdate() 、CCCryptorFinal() 和 CCCryptorRelease () 为每个 block 重复 CCCryptorUpdate() 。
参见 Mike Ash 的 Friday CommonCrypto 之旅。
关于ios - iOS 上的 AES128 加密,无需加载整个 NSData,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/24480966/
|