elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.


Tema destacado: Los 10 CVE más críticos (peligrosos) de 2020


+  Foro de elhacker.net
|-+  Programación
| |-+  Programación General
| | |-+  .NET (C#, VB.NET, ASP) (Moderador: kub0x)
| | | |-+  Cifrar variables o textos de forma sencilla.
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] 2 Ir Abajo Respuesta Imprimir
Autor Tema: Cifrar variables o textos de forma sencilla.  (Leído 9,095 veces)
Meta


Desconectado Desconectado

Mensajes: 3.501



Ver Perfil WWW
Cifrar variables o textos de forma sencilla.
« en: 29 Marzo 2018, 08:47 am »

Buenas gente:

Hice un ejemplo con este código.
Código
  1. using System;
  2.  
  3. namespace Encriptar_variable_Consola_01
  4. {
  5.    class Program
  6.    {
  7.        static void Main(string[] args)
  8.        {
  9.            Console.Title = "Ocultar variable"; // Título de la pantalla.
  10.  
  11.            string variable = "Esto es una prueba.";
  12.  
  13.            Console.WriteLine(variable);
  14.            Console.WriteLine("Otra prueba.");
  15.  
  16.            Console.ReadKey(); // Pulse cualquier tecla para salir.
  17.        }
  18.    }
  19. }

Mirando el ejecutable en el editor hexadecimal. Si encuentra los valores de las variables como indica la captura.


Uso Visual Studio 2017 Community. No quiero usar técnica de obfuscación, no se si esta versión la incluye. Quiero saber si existe la manera de camuflar esas variables.

Mi idea era usar algo parecido a esto en XOR ^10 con otro programa que haré a parte.

Código
  1.    for (int i = 0; i < variable.Length; i++)
  2.    {
  3.        variable[i] = (byte)(variable[i] ^ 10);
  4.    }

El código de ejemplo de una variable tipo array desordenarlo.

Luego copio y pego el resultado ya codificado en la variable que es el que estoy usando ahora. En este caso uso una variable tipo string.

Tengo que hacer de alguna manera, al ejecutar el programa, lea las variables codificadas y las vuelva a poner bien para que se lea en cristiano, luego lo guarda en otra variable y Console.WriteLine lo muestra.

Espero que se entienda lo que quiero decir o lo explico de otra manera.

¿Alguna ocurrencia?

Saludos.


En línea

Eleкtro
Ex-Staff
*
Desconectado Desconectado

Mensajes: 9.891



Ver Perfil
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #1 en: 29 Marzo 2018, 09:25 am »

Puedes usar la clase SecureString para asignar un string mediante el cifrado en un bloque de memoria no administrada, pero no se si esa solución se ajustará a las necesidades que tengas:

+

no se muy bien lo que quieres conseguir, y tampoco soy un experto en cifrado ni obfuscación avanzada, pero no veo que quieres conseguir mediante XOR para ocultar un string en el código IL...

Yo creo que el compañero @KuBoX debe tener buena idea sobre estos temas, a ver si se deja ver por aquí...

Saludos


« Última modificación: 29 Marzo 2018, 09:27 am por Eleкtro » En línea



Meta


Desconectado Desconectado

Mensajes: 3.501



Ver Perfil WWW
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #2 en: 29 Marzo 2018, 12:37 pm »

Hola:

Es exactamente lo que explicó nuestro amigo forero aquí, pero en vez de un array, un string que no se como se hace.

https://foro.elhacker.net/net/modificar_el_array_de_byte-t462782.0.html;msg2102256#msg2102256

Saludos.
En línea

srWhiteSkull


Desconectado Desconectado

Mensajes: 444



Ver Perfil WWW
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #3 en: 29 Marzo 2018, 13:41 pm »

En dotnet más fácil todavía, tienes AES y RSA que son muy difíciles de hackear:

https://msdn.microsoft.com/en-us/library/system.security.cryptography.aes(v=vs.110).aspx?cs-save-lang=1&cs-lang=csharp#code-snippet-2

https://msdn.microsoft.com/es-es/library/system.security.cryptography.rijndaelmanaged(v=vs.110).aspx?cs-save-lang=1&cs-lang=csharp#code-snippet-2

https://msdn.microsoft.com/es-es/library/system.security.cryptography.asymmetricalgorithm(v=vs.110).aspx

https://msdn.microsoft.com/es-es/library/system.security.cryptography.rsa(v=vs.110).aspx

En línea

Meta


Desconectado Desconectado

Mensajes: 3.501



Ver Perfil WWW
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #4 en: 29 Marzo 2018, 16:10 pm »

Gracias.

No quería tanto código, con una mini protección ya me vale.

Si tengo un array, hago este código y me basta.

Código
  1.    for (int i = 0; i < var1.Length; i++)
  2.    {
  3.        var1[i] = (byte)(var1[i] ^ 10);
  4.    }

Solo tengo este string que dice:

Código
  1. string var1 = "Esto es una prueba.";
  2. Console.WriteLine = var1;
  3.  

Cuando usas el for arriba otra vez que es un XOR ^10, con usar el mismo, vuelve los valores como estaba.

Ahora la variable var1 en su interior lo transforma en "mjcgpow5yp4g0,xy43ph". Si vuelvo aplicar el for pero con la variable var1 igual a mjcgpow5yp4g0,xy43ph, al final dice "Esto es una prueba.".

El for de arriba mira un array, pero en este caso es un string, en el cual no se que hacer para que funcione en un string. Ahí está mi problema.

Saludos.
En línea

Serapis
Colaborador
***
Desconectado Desconectado

Mensajes: 3.391


Ver Perfil
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #5 en: 30 Marzo 2018, 03:35 am »

En efecto es suficiente con XOR, para algo simple... pero no en la forma que haces.

Es preferible que uses una clave, que luego expandas hasta cierto tamaño... ese valor es el que usas para cifrar con XOR.

Tu problema con la cadena se resume en un problema de falta de conocimientos del lenguaje.
NET, dispone múltiples funciones de tratamiento de cadenas, alguna de ellas convierte una cadena en un array de bytes (busca GetBytes (creo recordar que en Codificacion)), algo más pobre sería tomar carácter a caracter y convertirlo a byte, pero sabiendo que son cadenas muy cortas (no tochos de 1Gb. por ejemplo) incluso es perfectamente válido... hasta 1Mb... o algo más será prácticamente inmediato...


Un ejemplo en pseudocódigoVB...
Código:
array de bytes = Funcion Code(String ElTexto, String LaClave)
    Array de bytes Cifrado() = text.encoding.Getbytes(Eltexto)
    Array de bytes Key() = encoding.GetBytes(Ampliar(LaClave, Cifrado.lenght))

    Bucle para k desde 0 hasta txt.lenght
        Cifrado(k) = Cifrado(k) xor key(k)
    Fin bucle

    Devolver Cifrado
Fin funcion

String = Funcion Decode(Array de bytes Cifrado, String LaClave)
    Array de bytes Key() = Ampliar(LaClave, Cifrado.lenght))

    Bucle para k desde 0 hasta txt.lenght
        Txt(k) = txt(k) xor key(k)
    Fin bucle

    Devolver text.Encoding.GetString(Eltexto)
Fin funcion

' Dado un texto, lo amplía hasta como mínimo el tamaño pedido.
'   en cada ciclo, se duplica el tamaño previo.
Array de bytes = Funcion Ampliar(string Key, entero Minimo)
    entero i, j, k
    array de bytes tmp()
    Array de bytes yeK() = encoding.GetBytes(Key)

    k= yek.Lenght: j=k
    Hacer mientras (k < minimo)
        k = ((k*2)-1)
        redimensionar tmp(0 a k)
        ' El byte primero es la media de los extremos, luego entre el 2ª y el penúltimo, luego entre el 3º y el antepenúltimo...
        ' el byte último es un xor entre los extremos, luego entre el 2ª y el penúltimo, luego entre el 3º y el antepenúltimo...
        ' es muy simple, pero puede complicarse todo lo que quieras... y para lo que necesitas es suficiente.
        bucle para i desde 0 hasta j
            tmp(i) = (yek(i) + yek(j-i) \2)
            tmp(k-i) = (yek(i) xor yek(j-i))
        fin bucle
        ' Se puede complicar más con otras fases: 2,3,4 alterando la forma o la forma en que los índices se conjugan.

         yeK = tmp ' asignamos un array al otro...
        j = k
    Repetir

    Devolver yeK
Fin funcion
' NOTA: Revisa... que es probable que tengas que corregir el tamaño del array temporal (k = ((k*2)-1) ), lo he hecho al vuelo, mientras escribo...


 ...por qué no?... usaremos de ejemplo, una de las 'contraseñas' más usadas en el planeta....

Array de Bytes cif() = Code(text1.text, "QWERTYUIOP")
Text2.Text = Decode(cif, "QWERTYUIOP")


Ni qué decir que la clave debe ser la misma en mabos casos...

Si no te vale tener de vuelta un array de bytes, porque por ejemplo tienes que mostrarlo en una caja de texto, y muchos bytes no son imprimibles, pués lo pasas por una función a Base64 y listo...


Text3.text = Convert.ToBase64String( Code(Text1.Text, "QWERTYUIOP"))
Text2.Text = Decode(convert.FromBase64String(text3.text), "QWERTYUIOP")
En línea

Meta


Desconectado Desconectado

Mensajes: 3.501



Ver Perfil WWW
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #6 en: 30 Marzo 2018, 12:01 pm »

Buenas campeón:

Deja ver si capto lo que cuentas. Con el XOR ^10 me vale y solo quiero eso. Me da que usas la idea del Windows form y mi idea es en modo consola.

Saludos.
En línea

Serapis
Colaborador
***
Desconectado Desconectado

Mensajes: 3.391


Ver Perfil
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #7 en: 31 Marzo 2018, 04:29 am »

Deja ver si capto lo que cuentas. Con el XOR ^10 me vale y solo quiero eso.

...Me da que usas la idea del Windows form y mi idea es en modo consola.
mmmm... a ver yo leí esto:
Citar
Mi idea era usar algo parecido a esto en XOR ^10 con otro programa que haré aparte.

Es decir, yo entiendo/interpreto que usas ese programa/librería aparte (B)...
1 - Primero para cifrar lo deseado y guardarlo en el ejecutable (A)...
2 - Luego cuando se carga esté 'A', invocar a 'B' para decodificarlo.
Yo veo que cumple perfectamente lo que quieres... (aunque tienes que adaptarlo, es solo un simple ejemplo)

De todos modos, yo ni siquiera usaría un programa/librería aparte, simplemente crearía un par de métodos de extensión, para la clase String (Code, Decode haciendo justo lo que señalo más abajo más arriba) y listo... y si me apuras, ni cifrando con XOR, dejándolo simplemente en Base64, te bastaría...
« Última modificación: 31 Marzo 2018, 04:32 am por NEBIRE » En línea

Serapis
Colaborador
***
Desconectado Desconectado

Mensajes: 3.391


Ver Perfil
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #8 en: 31 Marzo 2018, 16:13 pm »

...y bueno, aprovechando que es sábado y Semana Santa y que por ello tengo un poco de tiempo libre...

No acostumbro a poner código, creo que todo el que reclama algo tiene que entender lo que sele dice y poner de su parte, pero bueno... Tampoco es plan que pongan en duda, lo que uno dice, porque (al menos yo) lo que uno dice debe decirlo con conocimiento, si no es mejor callarse, ó ante la duda preguntar...

El código parte de las líneas que tienes tú, yo simplemente he añadido la extensión de los métodos para los que te señalaba más arriba, corrigiendo en efecto, los pequeños detalles que se escapan cuando escribes al vuelo la idea... esto es, funciona perfectamente.
Código
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5.  
  6.  
  7. namespace Encriptar_variable_Consola_01{
  8.    using CustomExtensions;
  9.    class Program{
  10.        static void Main(string[] args){
  11.            string Key = "QWERTYUIOP";
  12.            string s = "En un lugar de 'La Mancha', de cuyo nombre no quiero acordarme.";
  13.            string r, t;
  14.  
  15.            r = s.Code(Key);
  16.            System.Console.WriteLine("El texto original {0} cifrado con la clave {1}, da por resultado {2}", s, Key, r);
  17.            Console.WriteLine();
  18.            t = r.Decode(Key);
  19.            System.Console.WriteLine("...y vuelta atrás, el texto cifrado {0} con la clave {1}, nos devuelve al origen {2}", r, Key, t);
  20.  
  21.            Console.WriteLine();
  22.            Console.ForegroundColor = ConsoleColor.Yellow;
  23.            System.Console.WriteLine("Se comprueba que 's' = 't' {0} = {1}", s, t);
  24.            Console.ForegroundColor = ConsoleColor.White;
  25.  
  26.  
  27.  
  28.  
  29.  
  30.            Console.WriteLine();  
  31.            //Console.Title = "Ocultar variable"; // Título de la pantalla.
  32.            Console.Title = "Ocultar variable".Code(Key) ;  
  33.            //string variable = "Esto es una prueba.";
  34.            string variable = "Esto es una prueba.".Code(Key) ;
  35.            Console.WriteLine(variable);
  36.            //Console.WriteLine("Otra prueba.");
  37.            Console.WriteLine("Otra prueba.".Code(Key) );
  38.  
  39.            Console.WriteLine();
  40.            Console.ForegroundColor = ConsoleColor.Red;
  41.            Console.WriteLine("Pulse una tecla y observa como cambia el título de la consola a su estado decodificado...");
  42.            Console.ReadKey();
  43.            Console.Title = Console.Title.Decode(Key);
  44.  
  45.            Console.WriteLine("Pulse cualquier tecla para salir.");
  46.            Console.ReadKey();
  47.        }
  48.    }
  49. }
  50.  
  51.  
  52. namespace CustomExtensions{
  53.    //Los métodos extendidos, deben ser definidos como una clase estática.
  54.    public static class StringExtension    {        
  55.        public static string Code(this String ElTexto, String LaClave){
  56.            byte[] Cifrado = Encoding.UTF8.GetBytes(ElTexto);
  57.            byte[] Key = Encoding.UTF8.GetBytes(Ampliar(LaClave, Cifrado.Length));
  58.            byte k;
  59.  
  60.            for (k=0; k< Cifrado.Length; k++){
  61.                Cifrado[k] = (byte)(Cifrado[k] ^ Key[k]);
  62.            }
  63.  
  64.            return Convert.ToBase64String(Cifrado);
  65.        }
  66.  
  67.        public static string Decode(this string Cifrado, String LaClave){
  68.            byte[] Cif = Convert.FromBase64String(Cifrado);            
  69.            byte[] Key = Encoding.UTF8.GetBytes(Ampliar(LaClave, Cif.Length));
  70.            byte k;
  71.  
  72.            for (k = 0; k < Cif.Length; k++){
  73.                Cif[k] = (byte)(Cif[k] ^ Key[k]);
  74.            }
  75.            return Encoding.UTF8.GetString(Cif);
  76.        }
  77.  
  78.        private static string Ampliar(string Key, int Minimo){
  79.            int k, j, i;
  80.  
  81.            byte[] yeK = Encoding.UTF8.GetBytes(Key);
  82.            k = yeK.Length;
  83.            j = (k-1);
  84.            byte[] tmp= new byte[k];
  85.  
  86.            while (k < Minimo){
  87.                k = (k * 2);
  88.                Array.Resize(ref tmp, k); //redimensionar tmp(0 a k)
  89.                //' El byte primero es la media de los extremos, luego entre el 2ª y el penúltimo, luego entre el 3º y el antepenúltimo...
  90.                //' el byte último es un xor entre los extremos, luego entre el 2ª y el penúltimo, luego entre el 3º y el antepenúltimo...
  91.                //' es muy simple, pero puede complicarse todo lo que quieras... y para lo que necesitas es suficiente.
  92.                for (i = 0; i < j; i++) {
  93.                    tmp[i] = (byte) ((yeK[i] + yeK[j-i] ) >> 1) ;
  94.                    tmp[k-1-i] = (byte) (yeK[i] ^ yeK[j-i]);
  95.                }
  96.                //' Se puede complicar más con otras fases: 2,3,4 alterando la forma o la forma en que los índices se conjugan.
  97.  
  98.                yeK = tmp; //' asignamos un array al otro...
  99.                j = (k - 1);
  100.            }
  101.            return Encoding.UTF8.GetString(yeK);
  102.        }
  103.    }
  104. }
  105.  

NOTAS:
A --- Yo tengo el VS-2010, puede que para una versión más actual, pueda requerir algún cambio, el propio entorno, ya te sugerirá si algo es obsoleto o incluso si no lo reconoce.... por ejemplo los métodos Getbytes, GetString, podrían estar desplazados respecto de UTF8.
B --- Nunca ha manejado una versión 'Comunity', solo versiones Enterprise y Profesional, por lo que ignoro las limitaciones de las versiones Comunity, supongo que para algo tan sencillo, no deba afectarle.
C --- Fíjate en el detalle de importar el namespace, concretamente en la línea: using CustomExtensions;
D --- Al final me he mantenido firme (al pseudocódigo que puse) y he dejado el cifrado con XOR, aparte de codificar con Base64.
E --- Para probarlo y entenderlo bien, ejecútalo paso a paso (tecla F11).
F --- He añadido bastante 'verbosidad', en main, para reflejar el uso de los métodos Code y Decode.
G --- p.d.: Personalmente acostumbro a abrir las llaves en la línea previa, por lo que no estando acostumbrado pueda dar la impresión de que 'falta algo'... cuestión de gustos, solamente...
H --- ...y por supuesto y para aclarar tus dudas: Es una aplicaicón de consola, la frase tuya:  Me da que usas la idea del Windows form y mi idea es en modo consola.[/i] es irrelevante, aunque yo pusiera en el ejemplo referencias a unos controles textbox, el pseudocódigo es adaptable a ambas situaciones...
I --- Para algo más elegante, incluso la clave (QWERTYUIOP), podría estar cifrada (y ser descifrada, por ejemplo con el nombre del programa, con lo que si alguien lo cambia, 'traducirá' a urliburli), o bien ser pasada como un argumento al programa.
« Última modificación: 31 Marzo 2018, 16:32 pm por NEBIRE » En línea

Meta


Desconectado Desconectado

Mensajes: 3.501



Ver Perfil WWW
Re: Cifrar variables o textos de forma sencilla.
« Respuesta #9 en: 1 Abril 2018, 04:36 am »

Buenas:

Lo he probado. Funciona de maravilla.  ;-)

Tarda mucho en darle F11 todo el rato, pero se entiende. ;)

Lo que quería hacer era más sencillo, menos protección pero sencillo.

Programa A, el original, programa B el que hace el XOR ^10. Los dos hacen XOR ^10.

El tipo de varibale como ejemplo es el Byte[].
Código
  1.    byte[] rawData = {
  2.        0xF5, 0xD2, 0xF5, 0xEA, 0x0A, 0x1A, 0x40, 0x4C, 0x43, 0x4C, 0x0A, 0x0B,
  3.        0x0B, 0x0B, 0x0A, 0x42, 0x0A, 0x42, 0x0A, 0x0A, 0xF5, 0xD1, 0x0A, 0x49}

Usamos el XOR ^10.
Código
  1. for (int i = 0; i < rawData.Length; i++)
  2.    {
  3.        rawData[i] = (byte)(rawData[i] ^ 10);
  4.    }

El problema que tengo ahora, es que no uso Byte[], sino string. Por eso estoy para arriba y para abajo.

En vez de usar como ejemplo de arriba que puse Byte[], pongo un string en cristiano. No en códigos hexadecimales.

¿Hay alguna solución sobre lo que busco?

Salu2. ;)
« Última modificación: 1 Abril 2018, 04:39 am por Meta » En línea

Páginas: [1] 2 Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Insertar gifs de forma sencilla
Diseño Gráfico
panaka 5 3,326 Último mensaje 13 Marzo 2006, 22:57 pm
por panaka
[Source] Funcion sencilla para variables de entorno
Programación Visual Basic
nhaalclkiemr 3 2,765 Último mensaje 14 Febrero 2008, 17:46 pm
por nhaalclkiemr
Cifrar de forma segura una Pass en el Source « 1 2 »
.NET (C#, VB.NET, ASP)
z3nth10n 16 9,915 Último mensaje 1 Agosto 2013, 19:17 pm
por Novlucker
Acelera tus descargas P2P de forma sencilla
Noticias
wolfbcn 0 1,513 Último mensaje 23 Noviembre 2014, 01:34 am
por wolfbcn
Airflow es la forma más sencilla de enviar vídeos a Chromecast y Apple TV en ...
Noticias
wolfbcn 0 1,807 Último mensaje 26 Diciembre 2018, 14:09 pm
por wolfbcn
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines