c# - 在 Unity 中加密,在 Node.js 中解密

标签 c# javascript node.js encryption unity-game-engine

我正在尝试将一些数据从 Unity 发送到 Node.js Express 服务器,反之亦然。

这是我用 C# 编写的 Unity 代码:

public string Encrypt(string toEncrypt, string key, bool useHashing) 
{     

    byte[] keyArray;     
    byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(toEncrypt);      

    if (useHashing){               
        MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
        keyArray = hashmd5.ComputeHash(UTF8Encoding.UTF8.GetBytes(key));     
    }     
    else {
        keyArray = UTF8Encoding.UTF8.GetBytes(key);      
    }

    var tdes = new TripleDESCryptoServiceProvider();
    tdes.Key = keyArray;
    //tdes.Mode = CipherMode.CBC;  // which is default     
    //tdes.Padding = PaddingMode.PKCS7;  // which is default

    ICryptoTransform cTransform = tdes.CreateEncryptor();     
    byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
    tdes.Clear();
    return Convert.ToBase64String(resultArray, 0, resultArray.Length); 

}

    Dictionary<string, string> data = new Dictionary<string, string>();
    data.Add("Test01", "Tanmoy");
    data.Add("Test02", "Mitra");
    string json = Json.Serialize(data);

    byte[] postData = Encoding.UTF8.GetBytes(Encrypt(json, "12345", true));

    StartCoroutine(HttpPost("test", postData, delegate(string requestError, IDictionary rData) {
        cb(null,rData);
    }));

这是我的 Node.js 代码:

var alg = 'des-ede3-cbc';
var key = new Buffer('123456789012345678901234', 'utf-8');
var iv = new Buffer(m_strApiPass, 'base64');

var encrypted = new Buffer(reqString, 'base64');

var decipher = crypto.createDecipheriv(alg, key, iv);
var decoded = decipher.update(encrypted, 'binary', 'ascii');
decoded += decipher.final('ascii');

我收到此错误:

TypeError: error:0606506D:digital envelope routines:EVP_DecryptFinal_ex:wrong final block length

我注意到,在 C# 中,我得到了以下字符串,

pySqIdAiJpDOW7XkOQDoblLOtZ382J1G1F1UE16W0Ulg+x5X0Bocjg==

但是当我将此字符串发送到 Node.js 时,它变成:

pySqIdAiJpDOW7XkOQDoblLOtZ382J1G1F1UE16W0Ulg x5X0Bocjg  

问题可能是什么?

最佳答案

原因很简单:返回的密文由任何观察者看来都是随机的字节组成。这意味着其中存在未映射到字符的字节。这些字节内的信息会丢失。

如果您在传输过程中需要字符串,则使用 Base 64 编码您的密文,然后在接收端再次对其进行解码。

关于c# - 在 Unity 中加密,在 Node.js 中解密,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21256279/

相关文章:

javascript - 如何使用 post 参数重定向到外部 URL?

c# - 日期字段中具有可为空值的存储过程

c# - SingleProducerConstrained 和 MaxDegreeOfParallelism

javascript - 在扩展构造函数中调用函数

javascript - Mongoose - 按填充对象的字段搜索对象

javascript - 通过 Quickblox 推送通知

C# SQL SUM 值到标签

c# - C#中的自定义数字系统

javascript - jQuery.inArray 返回 -1,无论值如何

html - 发送和接收PCM样本