cifrar tramas de bytes

Iniciado por Meta, 20 Mayo 2009, 21:02 PM

0 Miembros y 1 Visitante están viendo este tema.

Meta

Buenas:
He hecho un programa con Visual C# Express 2008. Puedo enviar tramas desde Internet.
Cliente: Introduces un buuton1 y un textBox1.
Código (csharp) [Seleccionar]

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.IO;
using System.Net;
using System.Net.Sockets;

namespace Client
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            UdpClient udpClient = new UdpClient();
            udpClient.Connect(textBox1.Text, 60000);
            Byte[] sendBytes = Encoding.ASCII.GetBytes("Hola a todo el mundo...");
            udpClient.Send(sendBytes, sendBytes.Length);
        }
    }
}


Server:
Introduces un listBox1.
Código (csharp) [Seleccionar]

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Threading;
using System.Net.Sockets;
using System.Net;

namespace Server
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        public void serverThread()
        {
            UdpClient udpClient = new UdpClient(60000);
            while(true)
            {
                IPEndPoint RemoteIpEndPoint = new IPEndPoint(IPAddress.Any, 0);
                Byte[] receiveBytes = udpClient.Receive(ref RemoteIpEndPoint);
                string returnData = Encoding.ASCII.GetString(receiveBytes);
                 listBox1.Items.Add(RemoteIpEndPoint.Address.ToString() +
                    ":" + returnData.ToString());
            }
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            Thread thdUDPServer = new Thread(new
            ThreadStart(serverThread));
            thdUDPServer.Start();
        }
    }
}


Mi idea es que necesito encriptrar estas tramas que se envía a través  de Internet para que los sniffer (husmeadores) no cojan libremente los datos enviados. Los datos puedes ser textos de un chat.

He encontrado algo aquí, pero no entiendo nada.
http://msdn.microsoft.com/es-es/library/system.security.cryptography.des.aspx

Código (csharp) [Seleccionar]

private static void EncryptData(String inName, String outName, byte[] desKey, byte[] desIV)
{   
     //Create the file streams to handle the input and output files.
     FileStream fin = new FileStream(inName, FileMode.Open, FileAccess.Read);
     FileStream fout = new FileStream(outName, FileMode.OpenOrCreate, FileAccess.Write);
     fout.SetLength(0);

     //Create variables to help with read and write.
     byte[] bin = new byte[100]; //This is intermediate storage for the encryption.
     long rdlen = 0;              //This is the total number of bytes written.
     long totlen = fin.Length;    //This is the total length of the input file.
     int len;                     //This is the number of bytes to be written at a time.

     DES des = new DESCryptoServiceProvider();         
     CryptoStream encStream = new CryptoStream(fout, des.CreateEncryptor(desKey, desIV), CryptoStreamMode.Write);

     Console.WriteLine("Encrypting...");

     //Read from the input file, then encrypt and write to the output file.
     while(rdlen < totlen)
     {
         len = fin.Read(bin, 0, 100);
         encStream.Write(bin, 0, len);
         rdlen = rdlen + len;
         Console.WriteLine("{0} bytes processed", rdlen);
     }

     encStream.Close(); 
     fout.Close();
     fin.Close();                   
}


http://msdn.microsoft.com/es-es/library/system.security.cryptography.aspx
Tutoriales Electrónica y PIC: http://electronica-pic.blogspot.com/

MazarD

Qué es exactamente lo que no entiendes?

Para empezar es bueno tener una visión general de la cifrado que vas a utilizar, en el caso de DES es bastante importante:
http://es.wikipedia.org/wiki/Data_Encryption_Standard

Luego la función que has pegado simplemente recibe ruta de entrada, ruta de salida, clave y te genera el archivo cifrado, puedes probarlo llamandola así por ejemplo:

Código (csharp) [Seleccionar]

            byte[] llave= new byte[8]{0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11};
            byte[] iv= new byte[8] {0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11, 0x11};
            EncryptData("c:\\archivoAencriptar.txt", "c:\\archivoAgenerar.txt", llave, iv);


:P

Para descifrar, en la función de ejemplo que tienes, deberías cambiar createencryptor por createdecryptor y hacer que el stream fuera de lectura.
Bueno si tienes alguna duda concreta, comentalo.

Saludos!
-Learn as if you were to live forever, live as if you were to die tomorrow-

http://www.mazard.info
http://twitter.com/MazarD
irc://irc.freenode.org/elhacker.net