简体   繁体   English

PHP Triple DES加密和兼容的C#解密

[英]PHP Triple DES encryption and compatible C# decryption

I am decrypting a message in C#, this message is encrypted in PHP using below code:- 我在C#中解密一条消息,这条消息使用以下代码在PHP中加密: -

public function __construct($sEncryptionKey)
{
    $this->link = mcrypt_module_open('tripledes', '', 'ecb', '');
    $this->sInitializationVector = mcrypt_create_iv(mcrypt_enc_get_iv_size($this->link), MCRYPT_RAND);
    $this->iKeySize = mcrypt_enc_get_key_size($this->link);
    $sEncryptionKey = substr(md5($sEncryptionKey), 0, $this->iKeySize);
    mcrypt_generic_init($this->link, $sEncryptionKey, $this->sInitializationVector);
}

public function encrypt($sDataToEncrypt)
{
    return base64_encode(mcrypt_generic($this->link, $sDataToEncrypt));
}

And I am using below decryption function in c# for decryption:- 我在c#中使用以下解密功能进行解密: -

public string Decrypt(string toDecrypt, string key, bool useHashing)
{                      
    byte[] keyArray;
    byte[] toEncryptArray = Convert.FromBase64String(toDecrypt);    
    if (useHashing)
    {
        MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
        keyArray = hashmd5.ComputeHash(UTF8Encoding.UTF8.GetBytes(key));
        hashmd5.Clear();
    }
    else
    {
        keyArray = UTF8Encoding.UTF8.GetBytes(key);
    }

    TripleDESCryptoServiceProvider tdes = new TripleDESCryptoServiceProvider();               
    tdes.Key = keyArray;                                 
    tdes.Mode = CipherMode.ECB;                
    tdes.Padding = PaddingMode.Zeros;

    ICryptoTransform cTransform = tdes.CreateDecryptor();
    byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);                              
    tdes.Clear();
    var strValue = UTF8Encoding.UTF8.GetString(resultArray);    
    return UTF8Encoding.UTF8.GetString(resultArray);
}

I tried with few changes and getting below results:- 我尝试了一些变化并得到以下结果: -

1.) PaddingMode.PKCS7 with no hashing = "Specified key is not a valid size for this algorithm." 1.)PaddingMode.PKCS7没有散列=“指定的密钥不是此算法的有效大小。”

2.) PaddingMode.PKCS7 with hashing = "Bad Data." 2.)PaddingMode.PKCS7,hashing =“Bad Data”。

3.) PaddingMode.Zeros with no hashing = "Specified key is not a valid size for this algorithm." 3.)PaddingMode.Zeros没有散列=“指定的密钥不是此算法的有效大小。”

4.) PaddingMode.Zeros with hashing = " 8 f q6IGs " some unknown characters 4.)PaddingMode.Zeros with hashing =“ 8 f q6IGs ”一些未知字符

I think 4'th one will work, but not sure what I am doing wrong. 我认为第4个会起作用,但不确定我做错了什么。

Found a solution, need to do changes in MD5 hashing, below are whole code if someone stuck in same situation :- 找到一个解决方案,需要在MD5哈希中做更改,下面是整个代码,如果有人卡在同样的情况: -

public string Decrypt(string toDecrypt, string key, bool useHashing)
{
    TripleDESCryptoServiceProvider tdes = new TripleDESCryptoServiceProvider();
    byte[] keyArray;
    byte[] toEncryptArray = Convert.FromBase64String(toDecrypt);
    string keyArrayStr = "";
    if (useHashing)
    {
        MD5 md5 = MD5CryptoServiceProvider.Create();
        byte[] dataMd5 = md5.ComputeHash(Encoding.Default.GetBytes(key));
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < dataMd5.Length; i++)
            sb.AppendFormat("{0:x2}", dataMd5[i]);

        keyArrayStr = sb.ToString().Substring(0, tdes.Key.Length);
        keyArray = UTF8Encoding.UTF8.GetBytes(keyArrayStr);
    }
    else
    {
        keyArray = UTF8Encoding.UTF8.GetBytes(key);
    }

    tdes.Key = keyArray;
    tdes.Mode = CipherMode.ECB;
    tdes.Padding = PaddingMode.Zeros;

    ICryptoTransform cTransform = tdes.CreateDecryptor();
    byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
    tdes.Clear();
    var strValue = UTF8Encoding.UTF8.GetString(resultArray);
    return UTF8Encoding.UTF8.GetString(resultArray);
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM