3

我正在尝试在 Mono C# 中加密一些数据,将其发送到 NodeJS 服务器并在那里解密。我试图弄清楚使用什么算法来匹配这两者。

我发送用 base64 编码的加密字符串。所以我在 Javascript 中做了类似的事情,我知道用于加密 C# 应用程序中数据的密钥:

var decipher = crypto.createDecipher('aes192',binkey, biniv);
var dec = decipher.update(crypted,'base64','utf8');
dec += decipher.final('utf8');
console.log("dec", dec);

在 Mono 中,我使用以下命令创建我的 Cypher:

using System.Security.Cryptography;
using (Aes aesAlg = Aes.Create("aes192"))

我需要将正确的字符串传递给 Aes.Create() 以便让它使用相同的算法,但我找不到它应该是什么。“aes192”似乎不正确。

我不需要 aes192 这只是一个试用。如果有意义,建议使用不同的加密方式。安全性不是什么大问题。

以下是 .NET 和 Nodejs 文档的链接:http: //msdn.microsoft.com/en-us/library/system.security.cryptography.aes.aspx http://nodejs.org/api/crypto.html

4

3 回答 3

1

此代码适用于我的 Node.js 端,但请替换静态 iv,否则 aes 加密将无用。

var crypto = require('crypto');

function encrypt(data, key) {
    key = key || new Buffer(Core.config.crypto.cryptokey, 'binary'),
        cipher = crypto.createCipheriv('aes-256-cbc', key.toString('binary'), str_repeat('\0', 16));
    cipher.update(data.toString(), 'utf8', 'base64');
    return cipher.final('base64');
}

function decipher(data, key) {
    key = key || new Buffer(Core.config.crypto.cryptokey, 'binary'),
        decipher = crypto.createDecipheriv('aes-256-cbc', key.toString('binary'), str_repeat('\0', 16));
    decipher.update(data, 'base64', 'utf8');
    return decipher.final('utf8');
}

function str_repeat(input, multiplier) {
    var y = '';
    while (true) {
        if (multiplier & 1) {
            y += input;
        }
        multiplier >>= 1;
        if (multiplier) {
            input += input;
        } else {
            break;
        }
    }
    return y;
}

我希望这可以帮助你。

注意:您需要提供一个 265 位又名 32 个字符的密钥才能使该算法正常工作。

可能的 .NET 解决方案:这可能会对您有所帮助

于 2014-04-01T23:47:17.187 回答
0

你应该简单地写new AesManaged().
你不需要打电话Create()

然后您需要设置Keyand IV,然后调用CreateDecryptor()并将其放入CryptoStream.

于 2013-06-25T20:11:39.080 回答
0

结果证明这是一个愚蠢的错误。我认为 Node.js 中的 create 函数可以采用可变参数计数。原来你需要调用 createDecipheriv() 。

仅作记录,您可以通过查看 Aes 对象中的这些属性轻松检查填充和模式。默认值为 CBC 和 PKCS7。该填充也用于 nodejs 加密。因此,对于 128 密钥大小,我解密 base64 编码字符串的代码将是:

var crypto = require('crypto');
var binkey = new Buffer(key, 'base64');
var biniv = new Buffer(iv, 'base64');
var decipher = crypto.createDecipheriv('aes-128-cbc', binkey, biniv);
var decrypted = decipher.update(crypted,'base64','utf8');
decrypted += decipher.final('utf8');
console.log("decrypted", decrypted);
于 2013-06-27T14:35:03.650 回答