Mcrypt and base64 with PHP and c#

前端 未结 1 1009
后悔当初
后悔当初 2020-12-31 21:27

I have written the same methods in two platforms which I believe should result same thing but its not happening. I have encrypted the same text with same key which result di

相关标签:
1条回答
  • 2020-12-31 22:15

    C# does Rijndael padding by default and uses PKCS7.

    This means you have to pad your PHP side as per PKCS7, code below should work:

    function string_encrypt($string, $key) {
    
      $block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB);
      $padding = $block - (strlen($string) % $block);
      $string .= str_repeat(chr($padding), $padding);
    
        $crypted_text = mcrypt_encrypt(
                                MCRYPT_RIJNDAEL_128, 
                                $key, 
                                $string, 
                                MCRYPT_MODE_ECB
                            );
        return base64_encode($crypted_text);
    }
    

    For further information, see the first answer here

    I should add also, that if you want to change the C# side and not use padding, make the below modification instead and leave the PHP side alone:

    static string Encrypt(string plainText, string key)
    {
      string cipherText;
      var rijndael = new RijndaelManaged()
      {
        Key = Encoding.UTF8.GetBytes(key),
        Mode = CipherMode.ECB,
        BlockSize = 128,
        Padding = PaddingMode.Zeros,
      };
      ICryptoTransform encryptor = rijndael.CreateEncryptor(rijndael.Key, null);
    
      using (var memoryStream = new MemoryStream())
      {
        using (var cryptoStream = new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write))
        {
          using (var streamWriter = new StreamWriter(cryptoStream))
          {
            streamWriter.Write(plainText);
            streamWriter.Flush();
          }
          //cipherText = Convert.ToBase64String(Encoding.UTF8.GetBytes(Encoding.UTF8.GetString(memoryStream.ToArray())));
          cipherText = Convert.ToBase64String(memoryStream.ToArray());
          //cryptoStream.FlushFinalBlock();
        }
      }
      return cipherText;
    }
    
    0 讨论(0)
提交回复
热议问题