Миграция шифрования aes-256-ecb с узла на .NET - PullRequest
0 голосов
/ 20 июня 2019

Я пытаюсь перенести код шифрования, созданный на узле, на .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 есть больше параметров, во всяком случае я все протестировал, и ни один результат не совпадает.

1 Ответ

0 голосов
/ 20 июня 2019

Я сделал несколько (небольших) изменений, и все они работают как в Node.js, так и в .NET.

Код приведен ниже, я также создал DotNet Fiddle: здесь

И то же самое для кода Node.js. здесь

Node.js

// See /9018643/migratsiya-shifrovaniya-aes-256-ecb-s-uzla-na-net
const crypto = require("crypto");

// Change this if you're using for real !! 
const SECRET_KEY = Buffer.from("abcdefghijklmnopqrstuvwxyzabcdef", "utf8");

function GenerateTokenByLit(literal) {
    const text_encrypt = Buffer.from(literal, 'utf8');
    const cipher = crypto.createCipheriv('aes-256-ecb', SECRET_KEY, '');
    cipher.setAutoPadding(true);
    const text = cipher.update(text_encrypt, 'buffer', 'base64');
    return text + cipher.final('base64');
}

const plainText = "She's comin' on boys and she's comin' on strong.";
console.log("Plaintext: " + plainText);
console.log("Ciphertext: " + GenerateTokenByLit(plainText));

.NET

using System;
using System.Text;
using System.IO;
using System.Security.Cryptography;

public class Program
{
    public static readonly string SECRET_KEY = "abcdefghijklmnopqrstuvwxyzabcdef"; 

    public static void Main()
    {
        string plainText = "She's comin' on boys and she's comin' on strong.";
        Console.WriteLine("Plaintext: " + plainText);
        Console.WriteLine("Ciphertext: " + Encrypt(plainText) );
    }

    public static string Encrypt(string plainText)
    {
        byte[] KEY = Encoding.UTF8.GetBytes(SECRET_KEY); 
        byte[] encrypted;
        using (AesCryptoServiceProvider aesAlg = new AesCryptoServiceProvider())
        {
            aesAlg.Padding = PaddingMode.PKCS7;
            aesAlg.Mode = CipherMode.ECB;
            aesAlg.KeySize = 256;

            ICryptoTransform encryptor = aesAlg.CreateEncryptor(KEY, null);

            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.
                            swEncrypt.Write(plainText);
                        }
                        encrypted = msEncrypt.ToArray();
                    }
                }
        }
        return System.Convert.ToBase64String(encrypted);
    }
}
...