Я пытаюсь перенести код шифрования, созданный на узле, на .net.
Это узел:
function GenerateTokenByLit(literal) {
const text_encrypt = Buffer.from(literal, 'utf8');
const cipher = crypto.createCipheriv('aes-256-ecb', Buffer.from(SECRET_KEY, 'utf8'), '');
cipher.setAutoPadding(true);
const text = cipher.update(text_encrypt, 'buffer', 'base64');
return text + cipher.final('base64');
}
.NET код:
public static string Encrypt(string original)
{
byte[] iv = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
byte[] KEY = Encoding.UTF8.GetBytes(SECRET_KEY);
byte[] encrypted;
using (AesCryptoServiceProvider aesAlg = new AesCryptoServiceProvider())
{
aesAlg.Padding = PaddingMode.None;
aesAlg.Mode = CipherMode.ECB;
aesAlg.KeySize = 256;
// Create the streams used for encryption.
//const cipher = crypto.createCipheriv('aes-256-ecb', Buffer.from(constants.API_ENVRYPTED_KEY, 'utf8'), '');
//cipher.setAutoPadding(true);
using (ICryptoTransform encryptor = aesAlg.CreateEncryptor(KEY, iv))
using (MemoryStream msEncrypt = new MemoryStream())
using (CryptoStream csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write))
{
using (StreamWriter swEncrypt = new StreamWriter(csEncrypt))
{
//Write all data to the stream.
var bytes = Encoding.ASCII.GetBytes(original);
swEncrypt.Write(bytes);
}
encrypted = msEncrypt.ToArray();
}
}
return System.Convert.ToBase64String(encrypted);
}
Я думаю, что проблема в автозаполнении. В узле есть два параметра, false или true, но в .NET есть больше параметров, во всяком случае я все протестировал, и ни один результат не совпадает.