字符串在C#中加密使用TripleDES,需要在PHP中解密

C#代码看起来像那样(不能像在客户端的系统中那样改变它).

namespace Common {
public static class EncryptionHelper
{

   private const string cryptoKey = "password";

// The Initialization Vector for the DES encryption routine
   private static readonly byte[] IV = new byte[8] { 240, 3, 45, 29, 0, 76, 173, 59 };

/// <summary>
/// Encrypts provided string parameter
/// </summary>
public static string Encrypt(string s)
{

   string result = string.Empty;

   byte[] buffer = Encoding.ASCII.GetBytes(s);

   byte[] k = Encoding.ASCII.GetBytes(cryptoKey);

   TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();
   MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();


   des.Key = MD5.ComputeHash(ASCIIEncoding.ASCII.GetBytes(cryptoKey));

   des.IV = IV;

   result = Convert.ToBase64String(des.CreateEncryptor().TransformFinalBlock(buffer, 0, buffer.Length));

   return result;
  }
}
}

我发现客户从这里开始上课:http://johnnycoder.com/blog/2008/07/03/c-encryption-decryption-helper-class/

我对C#不是很熟悉,我需要用PHP加密解密字符串
这段代码.

当我执行“md5($key,true)”时,我得到的结果与“MD5.ComputeHash(ASCIIEncoding.ASCII.GetBytes(cryptoKey))”相同;“,不确定原因.

如何将“byte [] IV”转换为PHP字符串?

任何帮助,将不胜感激.
谢谢.

最佳答案 管理以使其工作:

class Crypter
{

/**
 *
 * Encryption key
 *
 * @var
 */
protected $key;

/**
 *
 * Encryption vector
 *
 * @var
 */
protected $iv;

public function __construct()
{

    $this->key = config('auth.triple_des_key');
    $this->iv = implode(array_map("chr", config('auth.triple_des_iv')));
}


/**
 *
 * Decrypts string using tripleDES method.
 *
 * @param $input String
 * @return String
 */
public function decryptTripleDES($input)
{

    $td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');

    $encryptedData = base64_decode($input);

    $key = iconv('utf-8', 'us-ascii//TRANSLIT', $this->key);

    $key = md5($key, true);
    $key .= substr($key, 0, 8);

    mcrypt_generic_init($td, $key, $this->iv);

    $decryptedData = mdecrypt_generic($td, $encryptedData);
    mcrypt_generic_deinit($td);

    //remove the padding text
    $block = mcrypt_get_block_size("tripledes", "cbc");

    $packing = ord($decryptedData{strlen($decryptedData) - 1});

    if ($packing and ($packing < $block)) {
        for ($P = strlen($decryptedData) - 1; $P >= strlen($decryptedData) - $packing; $P--) {
          if (ord($decryptedData[$P]) != $packing) {
              $packing = 0;
          }
      }
    }

    $decryptedData = substr($decryptedData, 0, strlen($decryptedData) - $packing);

    return $decryptedData;
}
}
点赞