在iOS中使用commoncrypto解密mp3文件(mp3文件使用openssl加密)

时间:2012-10-01 09:47:18

标签: ios objective-c ios5 encryption openssl

我有一个加密的MP3文件。该文件使用以下openssl方法加密

openssl enc -e -aes-128-cbc -K 00ff349830193845af43984758690213 -p -iv 0 -nosalt -in  input.mp3 -out output.mp3

然后我尝试在我的ios应用程序中解密文件,如下所示,

NSString *resourceDocPath = [[NSString alloc] initWithString:[[NSBundle mainBundle] bundlePath]] ;
NSString *filePath = [resourceDocPath stringByAppendingPathComponent:@"output.mp3"];
NSData *key = [@"00ff349830193845af43984758690213" dataUsingEncoding:NSUTF8StringEncoding];
NSData *iv = [@"00000000000000000000000000000000" dataUsingEncoding:NSUTF8StringEncoding];
NSData *fileData = [[NSData alloc] initWithContentsOfFile:filePath];
NSData *decryptData;

CCCryptorStatus ccStatus   = kCCSuccess;
size_t          cryptBytes = 0;    // Number of bytes moved to buffer.
NSMutableData  *dataOut    = [NSMutableData dataWithLength:fileData.length + kCCBlockSizeAES128];

ccStatus = CCCrypt(kCCDecrypt,
                   kCCAlgorithmAES128,
                   kSecPaddingNone,
                   key.bytes,
                   kCCKeySizeAES128,
                   iv.bytes,
                   fileData.bytes,
                   fileData.length,
                   dataOut.mutableBytes,
                   dataOut.length,
                   &cryptBytes);

if (ccStatus != kCCSuccess) {
    NSLog(@"CCCrypt status: %d", ccStatus);
}    
dataOut.length = cryptBytes;
decryptData = dataOut;

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *appFile = [documentsDirectory stringByAppendingPathComponent:@"MyDECFile.mp3"];
[decrypt writeToFile:appFile atomically:YES];
NSLog(@"%@",documentsDirectory);

现在我在文档目录中有解密的MP3文件,但它没有播放,字面意思是它的垃圾输出。请建议我一种获得所需输出的方法。

1 个答案:

答案 0 :(得分:4)

我使用https://github.com/rnapier/RNCryptor进行解密。

#import "ViewController.h"
#import <Security/Security.h>
#import <MediaPlayer/MediaPlayer.h>
#import "RNEncryptor.h"
#import "RNDecryptor.h"
#import "RNOpenSSLEncryptor.h"
#import "RNOpenSSLDecryptor.h"

NSString *resourceDocPath = [[NSString alloc] initWithString:[[NSBundle mainBundle] bundlePath]] ;
NSString *filePath1 = [resourceDocPath stringByAppendingPathComponent:@"output.mp3"]; //The encrypted mp3 file (with aPassword)
NSData *passEncryptedData =[[NSData alloc] initWithContentsOfFile:filePath1]; 
NSError *error;   
NSString *pass = @"aPassword";    
NSData *dataDecrypted = [RNOpenSSLDecryptor decryptData:passEncryptedData 
                                           withSettings:kRNCryptorAES256Settings
                                               password:pass
                                                  error:&error];

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *appFile = [documentsDirectory stringByAppendingPathComponent:@"passDecryptFile.mp3"]; //The Decrypted file saved here
[dataDecrypted writeToFile:appFile atomically:YES];
NSLog(@"%@",documentsDirectory);