c# - simetrica - UWP: encriptación y descifrado AES
encrypt string c# aes (1)
Tenía una clase simple para hacer un cifrado local básico para Windows Phone 8. Quería usar la clase nuevamente en una nueva aplicación UWP Windows 10 para Windows Store. Lamentablemente, ya no puedo usar la clase AesManaged.
Traté de usar Windows.Security.Cryptography.Core
, pero estoy completamente atascado. Esta es la clase original que utilicé para Windows Phone 8. Debo haberla encontrado en alguna parte en Internet en ese momento.
using System.Security.Cryptography;
namespace TestGame
{
public class AesEnDecryption
{
private string AES_Key = "MYLiSQ864FhDevJOeMs9EVp5RmfC7OuH";
private string AES_IV = "FoL5Tyd9sZclVn5A";
public string AES_encrypt(string Input)
{
var aes = new AesManaged();
aes.KeySize = 128;
aes.BlockSize = 128;
aes.Key = Convert.FromBase64String(AES_Key);
aes.IV = Encoding.UTF8.GetBytes(AES_IV);
var encrypt = aes.CreateEncryptor(aes.Key, aes.IV);
byte[] xBuff = null;
using (var ms = new MemoryStream())
{
using (var cs = new CryptoStream(ms, encrypt, CryptoStreamMode.Write))
{
byte[] xXml = Encoding.UTF8.GetBytes(Input);
cs.Write(xXml, 0, xXml.Length);
}
xBuff = ms.ToArray();
}
string Output = Convert.ToBase64String(xBuff);
return Output;
}
public string AES_decrypt(string Input)
{
var aes = new AesManaged();
aes.KeySize = 128;
aes.BlockSize = 128;
aes.Key = Convert.FromBase64String(AES_Key);
aes.IV = Encoding.UTF8.GetBytes(AES_IV);
var decrypt = aes.CreateDecryptor();
byte[] xBuff = null;
using (var ms = new MemoryStream())
{
using (var cs = new CryptoStream(ms, decrypt, CryptoStreamMode.Write))
{
byte[] xXml = Convert.FromBase64String(Input);
cs.Write(xXml, 0, xXml.Length);
}
xBuff = ms.ToArray();
}
string Output = Encoding.UTF8.GetString(xBuff, 0, xBuff.Length);
return Output;
}
}
}
¿Alguien sabe cómo traducir esto para las aplicaciones de UWP para Windows 10?
¡Gracias!
Debe leer la documentación sobre SymmetricAlgorithmProvider y CriptographicEngine.
Aquí tengo un pequeño ejemplo, cómo usar estos juntos:
using System;
using System.Linq;
using System.Runtime.InteropServices.WindowsRuntime;
using System.Text;
using Windows.Security.Cryptography;
using Windows.Security.Cryptography.Core;
using Windows.Storage.Streams;
namespace CryptTest
{
public class AesEnDecryption
{
// Key with 256 and IV with 16 length
private string AES_Key = "Y+3xQDLPWalRKK3U/JuabsJNnuEO91zRiOH5gjgOqck=";
private string AES_IV = "15CV1/ZOnVI3rY4wk4INBg==";
private IBuffer m_iv = null;
private CryptographicKey m_key;
public AesEnDecryption()
{
IBuffer key = Convert.FromBase64String(AES_Key).AsBuffer();
m_iv = Convert.FromBase64String(AES_IV).AsBuffer();
SymmetricKeyAlgorithmProvider provider = SymmetricKeyAlgorithmProvider.OpenAlgorithm(SymmetricAlgorithmNames.AesCbcPkcs7);
m_key = provider.CreateSymmetricKey(key);
}
public byte[] Encrypt(byte[] input)
{
IBuffer bufferMsg = CryptographicBuffer.ConvertStringToBinary(Encoding.ASCII.GetString(input), BinaryStringEncoding.Utf8);
IBuffer bufferEncrypt = CryptographicEngine.Encrypt(m_key, bufferMsg, m_iv);
return bufferEncrypt.ToArray();
}
public byte[] Decrypt(byte[] input)
{
IBuffer bufferDecrypt = CryptographicEngine.Decrypt(m_key, input.AsBuffer(), m_iv);
return bufferDecrypt.ToArray();
}
}
}
Cuando desee utilizar otro algoritmo, AesCbcPkcs7
, deberá cambiar el nombre SymmetricAlgorithmName