2015-06-26 3 views
2

Im пытается расшифровать мой файл в IOS. файл зашифрован AES в приложении C#.AES Расшифровка в IOS, не дающая точного результата

это мой IOS дешифрование Метод:

- (NSData *)AES128Operation:(CCOperation)operation key:(NSString *)key iv:(NSString *)iv 
{ 
    NSLog(@"inside AES128Operation"); 
    char keyPtr[kCCKeySizeAES128 + 1]; 
    bzero(keyPtr, sizeof(keyPtr)); 
    [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding]; 

    char ivPtr[kCCBlockSizeAES128 + 1]; 
    bzero(ivPtr, sizeof(ivPtr)); 
    if (iv) { 
     [iv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding]; 
    } 

    NSUInteger dataLength = [self length]; 
    size_t bufferSize = dataLength + kCCBlockSizeAES128; 
    void *buffer = malloc(bufferSize); 

    size_t numBytesEncrypted = 0; 
    CCCryptorStatus cryptStatus = CCCrypt(operation, 
              kCCAlgorithmAES128, 
              kCCOptionPKCS7Padding | kCCOptionECBMode, 
              keyPtr, 
              kCCBlockSizeAES128, 
              ivPtr, 
              [self bytes], 
              dataLength, 
              buffer, 
              bufferSize, 
              &numBytesEncrypted); 

    if (cryptStatus == kCCSuccess) { 
     return [NSData dataWithBytes:buffer length:numBytesEncrypted]; 
    } 
    free(buffer); 
    return nil; 
} 

И путь им пользоваться:

NSString *strKey = MyKey; 
NSString *strIv = MyIV; 
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES); 
NSString *documentsDir = [paths objectAtIndex:0]; 
NSString *pathLocal_encrypted = [documentsDir stringByAppendingPathComponent:@"encrypted.file"]; 

NSData *data_encrpted = [[NSFileManager defaultManager] contentsAtPath:pathLocal_encrypted]; 

NSData *decryptedData = [data_encrpted AES128DecryptedDataWithKey:strKey iv:strIv]; 

IV является 8 байт Вектор. Окончательный расшифрованный файл нечитабельно или сильно дешифрован. Я также пробовал шифровать/расшифровывать внутри приложения ios с помощью метода «AES128Operation» в каком-либо тестовом файле, и он работает хорошо, но не знает, почему он не может расшифровать зашифрованный файл C#.

дешифрования Хорошо работает в C# с этим кодом (тот же файл, Same IV, То же, Key):

static byte[] GetBytes(string str) 
    { 
     byte[] bytes = new byte[str.Length * sizeof(char)]; 
     System.Buffer.BlockCopy(str.ToCharArray(), 0, bytes, 0, bytes.Length); 
     return bytes; 
    } 

    private static byte[] DecryptBytes(SymmetricAlgorithm alg, byte[] message) 
    { 
     if ((message == null) || (message.Length == 0)) 
     { 
      return message; 
     } 
     using (var stream = new MemoryStream()) 
     { 
      using (var decryptor = alg.CreateDecryptor()) 
      using (var encrypt = new CryptoStream(stream, decryptor, CryptoStreamMode.Write)) 
      { 
       encrypt.Write(message, 0, message.Length); 
       encrypt.FlushFinalBlock(); 
      } 
      return stream.ToArray(); 
     } 
    } 
       path = openFileDialog1.FileName; 
       byte[] encMessage = StreamFile(path); 
       byte[] decMessage; 

       byte[] rkey = GetBytes(Mykey); 
       byte[] riv = GetBytes(MyIv); 
       using (var rijndael = new RijndaelManaged()) 
       { 
        rijndael.Key = rkey; 
        rijndael.IV = riv; 
        decMessage = DecryptBytes(rijndael, encMessage); 
       } 

из-за ответ предложение ив попробовал это один к, но до сих пор нет надежды:

NSData *key = [NSData dataWithData:[strKey dataUsingEncoding:NSUTF8StringEncoding]]; 
    NSData *iv = [NSData dataWithData:[strIv dataUsingEncoding:NSUTF8StringEncoding]]; 
    NSData *decryptedData = [self doCipher:data_encrpted iv:iv key:key context:kCCDecrypt]; 

и новая функция:

- (NSData *)doCipher:(NSData *)dataIn 
        iv:(NSData *)iv 
       key:(NSData *)symmetricKey 
      context:(CCOperation)encryptOrDecrypt 
{ 

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

    ccStatus = CCCrypt(encryptOrDecrypt, 
         kCCAlgorithmAES128, 
         kCCOptionPKCS7Padding, 
         symmetricKey.bytes, 
         kCCKeySizeAES128, 
         iv.bytes, 
         dataIn.bytes, 
         dataIn.length, 
         dataOut.mutableBytes, 
         dataOut.length, 
         &cryptBytes); 


     NSLog(@"CCCrypt status: %d", ccStatus); 


    dataOut.length = cryptBytes; 
    NSLog(@"CCCrypt ataOut.length: %d", dataOut.length); 
    return dataOut; 
} 

это шифрование \ установка дешифрования внутри C#:

public RijndaelManaged GetRijndaelManaged(string secretKey, string iv) 
    { 
     var keyBytes = new byte[16]; 
     var secretKeyBytes = Encoding.UTF8.GetBytes(secretKey); 
     Array.Copy(secretKeyBytes, keyBytes, Math.Min(keyBytes.Length, secretKeyBytes.Length)); 

     var ivBytes = new byte[16]; 
     var secretIvBytes = Encoding.UTF8.GetBytes(iv); 
     Array.Copy(secretIvBytes, ivBytes, Math.Min(ivBytes.Length, secretIvBytes.Length)); 

     return new RijndaelManaged 
     { 
      Mode = CipherMode.CBC, 
      Padding = PaddingMode.PKCS7, 
      KeySize = 128, 
      BlockSize = 128, 
      Key = keyBytes, 
      IV = ivBytes 
     }; 
    } 

    public byte[] Encrypt(byte[] plainBytes, RijndaelManaged rijndaelManaged) 
    { 
     return rijndaelManaged.CreateEncryptor() 
      .TransformFinalBlock(plainBytes, 0, plainBytes.Length); 
    } 

    public byte[] Decrypt(byte[] encryptedData, RijndaelManaged rijndaelManaged) 
    { 
     return rijndaelManaged.CreateDecryptor() 
      .TransformFinalBlock(encryptedData, 0, encryptedData.Length); 
    } 
+0

Был ли ваш чек, какие дополнения и режим были использованы в C#? – Doro

+0

Проблема в том, что у меня нет доступа к исходному коду C#. , но когда я использую дешифрование по умолчанию rijndael, оно работает хорошо. –

+0

@ Андрей Марков См. Вопрос и ответ в [SO question] (http://stackoverflow.com/q/31067324/451475). Кстати, есть ли какая-то связь между этими вопросами? Они настолько похожи и спрошены с часом друг друга. – zaph

ответ

1

капельницы для AES является таким же, как размер блока: 128 бит (16 байт), вопрос гласит: «IV представляет собой 8 байт Вектор» что неверно.

Поскольку вы используете iv, режим должен быть CBC, но код указывает kCCOptionECBMode, удалите это, по умолчанию в iOS (Common Crypto) используется режим CBC.

Обратите внимание, что RijndaelManaged по умолчанию используется режим CBC и дополнение PKCS # 7. Но размер ключа, если он явно не установлен, определяется длиной предоставленного ключа и заполняется нулем до поддерживаемой длины ключа. Лучше явно установить это значение, в RijndaelManaged используйте параметр KeySize (в битах).

Размер блока для AES составляет 128 бит, но RijndaelManaged поддерживает несколько размеров блоков, AESManaged - лучший выбор для шифрования AES. Это, вероятно, не проблема. Лучше явно установить это значение, в RijndaelManaged используйте параметр BlockSize со значением 128.

+0

спасибо за ответ. ive получил доступ к файлу шифрования/расшифровки и обновил мой вопрос. –

1

В документации говорится в режиме C# по умолчанию (AesManaged.Mode собственности):

One of the enumeration values that specifies the block cipher mode to use for encryption. The default is CBC. 

Так, в ИОС вы должны также расшифровать данные в режиме CBC.

Удалить kCCOptionECBMode из кода дешифрования

Что касается дополнения:

Значение свойства Тип: System.Security.Cryptography.PaddingMode Один из значения перечисления, которое определяет тип прокладки для применения. По умолчанию используется PKCS7.

Таким образом, проверьте код дешифрования для правильного Params

+0

спасибо за предложение, ive попробовал, что и упоминает, но все же файл нечитаем. Обновил мой вопрос –

Смежные вопросы