使用 3DES EDE / ECB / NOPadding 加密

本文关键字:NOPadding 加密 ECB 使用 EDE 3DES | 更新日期: 2023-09-27 18:37:20

我收到了一个任务,使用 TOKEN 和 KEY 加密和解密 XML 字符串。加密应使用3DES EDE / ECB / NOPadding,可以PHPC#

我对此没有那么准备,所以我阅读了一些理论,并得出了一个非常简单的实现,如下所示:

public string Encrypt( string message, string key, string token ) {
    byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes( message );
    byte[] keyArray = CreateHash( key );
    byte[] vectorArray = CreateHash( token );
    TripleDESCryptoServiceProvider tdes = new TripleDESCryptoServiceProvider();
    //set the secret key for the tripleDES algorithm
    tdes.Key = keyArray;
    //mode of operation. there are other 4 modes. We choose ECB(Electronic code Book)
    tdes.Mode = CipherMode.ECB;
    //padding mode(if any extra byte added)
    tdes.Padding = PaddingMode.None;
    ICryptoTransform cTransform = tdes.CreateEncryptor(keyArray, vectorArray);
    //transform the specified region of bytes array to resultArray
    byte[] resultArray = cTransform.TransformFinalBlock( toEncryptArray, 0, toEncryptArray.Length );
    //Release resources held by TripleDes Encryptor
    tdes.Clear();
    //Return the encrypted data into unreadable string format
    return Convert.ToBase64String( resultArray, 0, resultArray.Length );
}
private byte[] CreateHash( string toHash ) {
    //use get hashcode regards to your key
    MD5CryptoServiceProvider hashKey = new MD5CryptoServiceProvider();
    byte[] kArray = hashKey.ComputeHash( UTF8Encoding.UTF8.GetBytes( toHash ) );
    //Always release the resources and flush data
    //of the Cryptographic service provide. Best Practice
    hashKey.Clear();
    return kArray;
}

但是我认为这并不完全正确。事实上,我不确定TOKEN是否应该以这种方式使用。有人可以提供更多信息并指出如何解决这个问题的正确方向吗?

谢谢

使用 3DES EDE / ECB / NOPadding 加密

您可以在 TripleDESCryptoServiceProvider 上使用 token 作为向量,以及密钥。

ICryptoTransform cTransform = tdes.CreateEncryptor(key, token);