菜鸟教程小白 发表于 2022-12-11 21:59:59

iphone - Objective-C 解密 AES 128 cbc 十六进制字符串


                                            <p><p>我正在使用 Xcode 3.1 在 Snow Leopard 上为 iPhone 开发一个应用程序,该应用程序从一个安静的 Web 服务接收一个使用 AES 128 位 (CBC) 算法的十六进制格式的加密文本。该算法使用初始化向量 +key 。如何解密此文本?感谢大家提供的提示,我将成功提供。</p>

<p>编辑:
我从 REST 服务器收到十六进制和加密格式的响应,我尝试使用此代码,但我总是收到错误的参数错误。你能帮我找出错误吗?
我可以先将字符串响应转换为二进制格式吗?</p>

<pre><code>      NSString *response = ;

      NSData *encryptedData = ;
      NSString *key= @&#34;32charlength&#34;;
      NSString *iv   = @&#34;16charlength&#34;;
      NSData *unencryptedData = NULL;
      size_t unencryptedLength = ;
      CCCryptorStatus ccStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128, 0, key, kCCKeySizeAES128, iv, , , unencryptedData, , &amp;unencryptedLength);   
      NSString *output = [ initWithBytes:unencryptedData length:unencryptedLength encoding:NSUTF8StringEncoding];

      if (ccStatus == kCCSuccess) risultato.text = @&#34;SUCCESS&#34;;
      else if (ccStatus == kCCParamError) risultato.text =@&#34;BAD PARAM&#34;;
      else if (ccStatus == kCCBufferTooSmall) risultato.text =@&#34;BUFFER TOO SMALL&#34;;
      else if (ccStatus == kCCMemoryFailure) risultato.text =@&#34;MEMORY FAILURE&#34;;
      else if (ccStatus == kCCAlignmentError) risultato.text =@&#34;ALIGNMENT&#34;;
      else if (ccStatus == kCCDecodeError) risultato.text =@&#34;DECODE ERROR&#34;;
      else if (ccStatus == kCCUnimplemented)risultato.text = @&#34;UNIMPLEMENTED&#34;;
</code></pre>

<p>编辑2:
此函数返回 BAD PARAM,因为没有正确的缓冲区大小来分配解密数据。我以这种工作方式编辑函数:</p>

<pre><code>      NSData *encryptedData = ;
      const void *key= @&#34;32charlength;
      uint8_t *iv      = @&#34;16charlength&#34;;
      char buffer;
      memset(buffer, &#39;\0&#39;, sizeof(buffer));
            size_t size = sizeof(buffer);
      CCCryptorStatus ccStatus = CCCrypt(kCCDecrypt,
                                       kCCAlgorithmAES128,
                                       0,
                                       key,
                                       kCCKeySizeAES128,
                                       iv,
                                       ,
                                       ,
                                       buffer,
                                       sizeof(buffer),
                                       &amp;size);
</code></pre>

<p>这个功能对我有用.. 非常感谢。</p>

<p>编辑 3 月 23 日------</p>

<p>现在系统以 16 字节的 key 大小工作。现在我有一个问题,我能做些什么来实现 32 字节的 key 大小?非常感谢。</p></p>
                                    <br><hr><h1><strong>Best Answer-推荐答案</ strong></h1><br>
                                            <p><p>这可以使用 <code><CommonCrypto/CommonCryptor.h></code>header 中包含的 <code>CCCryptor</code> 函数来实现。检查 <code>man CCCryptor</code> 以获得血腥细节,在你的情况下,听起来你可以使用一次调用 <code>CCCrypt()</code> 来解码接收到的数据:</p>

<pre><code>CCCryptorStatus
CCCrypt(CCOperation op, CCAlgorithm alg, CCOptions options, const void *key, size_t keyLength,
   const void *iv, const void *dataIn, size_t dataInLength, void *dataOut, size_t dataOutAvailable,
   size_t *dataOutMoved);
</code></pre>

<p>假设您有要在 <code>NSData *encryptedData</code> 中解密的数据,您可以尝试以下操作:</p>

<pre><code>char * key = &#34;shouldbe16chars.&#34;;
NSUInteger dataLength = ;
uint8_t unencryptedData;
size_t unencryptedLength;

CCCrypt(kCCDecrypt, kCCAlgorithmAES128, 0, key, kCCKeySizeAES128, NULL, , dataLength, unencryptedData, dataLength, &amp;unencryptedLength);
NSString *output = [ initWithBytes:unencryptedData length:unencryptedLength encoding:NSUTF8StringEncoding];
</code></pre>

<p>这是未经测试的,请确保检查 <code>CCCrypt</code> 的返回值是否有错误。详情查看头文件,有据可查。</p></p>
                                   
                                                <p style="font-size: 20px;">关于iphone - Objective-C 解密 AES 128 cbc 十六进制字符串,我们在Stack Overflow上找到一个类似的问题:
                                                        <a href="https://stackoverflow.com/questions/9682118/" rel="noreferrer noopener nofollow" style="color: red;">
                                                                https://stackoverflow.com/questions/9682118/
                                                        </a>
                                                </p>
                                       
页: [1]
查看完整版本: iphone - Objective-C 解密 AES 128 cbc 十六进制字符串