菜鸟教程小白 发表于 2022-12-12 15:39:09

c# - IOS 中的 AES 解密没有给出确切的结果


                                            <p><p>我正在尝试在 IOS 中解密我的文件。该文件在 C# 应用程序中使用 AES 加密。</p>

<p>这是我的IOS解密方法:</p>

<pre><code>- (NSData *)AES128Operation:(CCOperation)operation key:(NSString *)key iv:(NSString *)iv
{
    NSLog(@&#34;inside AES128Operation&#34;);
    char keyPtr;
    bzero(keyPtr, sizeof(keyPtr));
    ;

    char ivPtr;
    bzero(ivPtr, sizeof(ivPtr));
    if (iv) {
      ;
    }

    NSUInteger dataLength = ;
    size_t bufferSize = dataLength + kCCBlockSizeAES128;
    void *buffer = malloc(bufferSize);

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

    if (cryptStatus == kCCSuccess) {
         return ;
    }
    free(buffer);
    return nil;
}
</code></pre>

<p>以及我使用它的方式:</p>

<pre><code>NSString *strKey = MyKey;
NSString *strIv = MyIV;
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES);
NSString *documentsDir = ;
NSString *pathLocal_encrypted = ;

NSData *data_encrpted = [ contentsAtPath:pathLocal_encrypted];

NSData *decryptedData = ;
</code></pre>

<p>IV 是一个 8 字节的向量。
最终解密的文件不可读或解密错误。
我还在一些测试文件上使用“AES128Operation”方法尝试在 ios 应用程序中加密/解密,它运行良好但不知道为什么它不能解密 C# 加密文件。 </p>

<p>使用此代码(相同文件、相同 iv、相同、 key )在 C# 中解密效果很好:</p>

<pre><code>    static byte[] GetBytes(string str)
    {
      byte[] bytes = new byte;
      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);
                }
</code></pre>

<p>由于回答建议我尝试了这个但仍然没有希望:</p>

<pre><code>    NSData *key = ];
    NSData *iv = ];
    NSData *decryptedData = ;
</code></pre>

<p>和新功能:</p>

<pre><code>- (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    = ;

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


      NSLog(@&#34;CCCrypt status: %d&#34;, ccStatus);


    dataOut.length = cryptBytes;
    NSLog(@&#34;CCCrypt ataOut.length: %d&#34;, dataOut.length);
    return dataOut;
}
</code></pre>

<p>这是 C# 中的加密\解密设置:</p>

<pre><code>   public RijndaelManaged GetRijndaelManaged(string secretKey, string iv)
    {
      var keyBytes = new byte;
      var secretKeyBytes = Encoding.UTF8.GetBytes(secretKey);
      Array.Copy(secretKeyBytes, keyBytes, Math.Min(keyBytes.Length, secretKeyBytes.Length));

      var ivBytes = new byte;
      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);
    }
</code></pre></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p>AES 的 iv 与 block 大小相同:128 位(16 字节),问题指出:“IV 是一个 8 字节向量”,这是不正确的。</p>

<p>由于您使用的是 iv,因此模式应为 CBC,但代码指定了 <code>kCCOptionECBMode</code>,请删除它,iOS(通用加密)上的默认设置为 CBC 模式。</p>

<p>请注意,<code>RijndaelManaged</code> 默认为 CBC 模式和 PKCS#7 填充。但是,如果未明确设置,则 key 大小由所提供 key 的长度决定,并被填充为支持的 key 长度。最好显式设置它,在 <code>RijndaelManaged</code> 中使用 <code>KeySize</code> 参数(以位为单位)。</p>

<p>AES 的 block 大小为 128 位,但 <code>RijndaelManaged</code> 支持多种 block 大小,<code>AESManaged</code> 是 AES 加密的更好选择。这可能不是问题。最好显式设置它,在 <code>RijndaelManaged</code> 中使用值为 128 的 <code>BlockSize</code> 参数。</p></p>
                                   
                                                <p style="font-size: 20px;">关于c# - IOS 中的 AES 解密没有给出确切的结果,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/31066698/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/31066698/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: c# - IOS 中的 AES 解密没有给出确切的结果