anun1

lunes, 23 de febrero de 2026

Remplazar string de un archivo ejecutable o binario en C++

Hola, amigos hoy les dejaré un código en c++ el cual remplazar un valor Spring por otro desde c++, ya que en JavaScript no pude hacerlo y no me quise complicar la vida lo realice en c++, este programa o ejercicio como lo quieran llamar primeramente lo mire de un amigo, no sé si fue necroxia u otro usuario del grupo crackslatinos no recuerdo quien, pero él lo realizo en aquel tiempo en vb6, pero como vb6 ya quedo para la historia yo lo realice en otro lenguaje.

Nota:este programa no remplaza o lee valores Unicode

bueno aquí una imagen del ejecutable que le vamos a remplazar el string, solo al darle clic nos muestra esto

.

Bueno ahora abriremos el editor de c++ y pegamos el siguiente código
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>

using namespace std;

int main()
{
    string ruta,buscar,reemplazar; //Evaluation  felicidade
    
    cout<<"Dame la ruta del archivo: ";
    cin>>ruta;
    
    cout<<"Dame el texto a buscar: ";
    cin>>buscar;
    
    cout<<"Dame el texto a remplazar, DEBE SER DE LA MISMA CANTIDAD DE CARACTERES: ";
    cin>>reemplazar;

    if (buscar.size() != reemplazar.size())
    {
        cout << "Error: deben tener el mismo tamaño\n";
        return 1;
    }

    // Abrir archivo
    fstream file(ruta, ios::binary | ios::in | ios::out);

    if (!file)
    {
        cout << "No se pudo abrir\n";
        return 1;
    }

    // Leer todo el archivo
    file.seekg(0, ios::end);
    streamsize size = file.tellg();
    file.seekg(0, ios::beg);

    vector<char> buffer(size);
    file.read(buffer.data(), size);

    // Buscar
    auto it = search(buffer.begin(), buffer.end(),
                     buscar.begin(), buscar.end());

    if (it == buffer.end())
	{
        cout << "Texto no encontrado...Nota:Este programa no lee valores unicode\n";
        file.close();
        return 1;
    }

    // Calcular posición
    streamsize pos = distance(buffer.begin(), it);

    cout << "Encontrado en: " << pos << endl;

    // Reemplazar en memoria
    for (size_t i = 0; i < reemplazar.size(); i++)
    {
        buffer[pos + i] = reemplazar[i];
    }

    // Volver al inicio y escribir todo
    file.seekp(0, ios::beg);
    file.write(buffer.data(), size);

    file.close();

    cout << "Reemplazo completado\n";

    return 0;
}

Damos compilar y ejecutar



El ejecutable que tome como ejemplo es un crackme llamado reverseMe.exe y lo tengo en la misma carpeta donde tengo el código de este programa por esa razón solo puse su nombre y no toda una ruta.


La palabra a buscar es license y la remplazaré por 1234567 y al hacerlo me muestra el mensaje que se realizó con éxito así que ahora ejecutamos el crackme y me muestra el siguiente mensaje


Bueno creo que eso es todo y espero les guste, otra cosa ya tengo la solución de ese crackme, es algo sencillo a ver si lo publico en el foro del hacker.net y en underc0de

Nos vemos hasta la próxima Flamer y saludos a necroxia y a todos los Crackslatinos


domingo, 22 de febrero de 2026

Generador De Claves Del Crackme 3 De RedH@wK

Hola amigos hoy traigo el generador de claves del reto 3 de RedH@wK... Es algo sencillo ya que vean el código sabrán por qué, y entretenido, porque no hay algún crackme sencillo para pasar el rato y que te levante el ánimo; no se compara el ánimo como un reto difícil, pero es casi igual... En fin, aquí una foto del reto

 .

Ahora el código en HTML y JavaScript.

<html>
<head>
<title>Generador De Claves Del Crackme 3 De RedH@wK ...:::By Flamer:::...</title>
</head>
<body bgcolor="black">
<center>
<marquee style="font-size:30;color:yellow;">Generador De Claves Del Crackme 3 De RedH@wK ...:::By Flamer:::...</marquee><br><br>
<label style="color:white;">ID:&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp</label>
<input type="text" id="id" size='50' style="background-color:Gray;color:white;text-align:center;">
<input type="button" value="Copy" onclick="copiar1()">
<br><br>
<label style="color:white;">Serial:&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp&nbsp</label>
<input type="text" id="pass" size='50' style="background-color:Gray;color:white;text-align:center;">
<input type="button" value="Copy" onclick="copiar2()">
<br><br>
<input type="button"  value="Generar" onclick="generar()">
<input type="button"  value="Limpiar" onclick="limpia()"><br><br>

</center>
<script>
function copiar1() 
{
   let c=document.getElementById('nick'); 
   c.select();
   document.execCommand('copy');
}
function copiar2() 
{
   let c=document.getElementById('pass'); 
   c.select();
   document.execCommand('copy');
}
function limpia()
{
   document.getElementById("nick").value="";
   document.getElementById("pass").value="";
}
function generar()
{   
   let id=document.getElementById("id").value;
   let i,digi,clave;
   if(id=="")
   {
      alert("Error el campo esta vacio");
   }
   else
   {
       i=id.substr(0,1); //tama el primer valor del string
       digi=i.charCodeAt(0); //lo comvierte a su valor ascii
       clave=(digi*152700)+75000000+900; //lo multiplica y lo suma
       document.getElementById("pass").value=clave;
   }
}
</script>
</body>
</html>

Ahora lo probaremos insertando la palabra Flamer y nos da lo siguiente en el generador de claves.


Bueno, inserté Flamer y nos dio el valor de 85689900, así que lo probaremos.


Nos muestra el mensaje correcto, así que final feliz... Reto resuelto, creo que eso es todo, espero les guste y miren el código.

saludos Flamer


lunes, 16 de febrero de 2026

Cifrar Archivos con JavaScript y PowerShell

Hola amigos hoy vengo con un cifrador sencillo, les digo sencillo por que solo utiliza un xor nada mas y creo que es revertible en fin....pero ustedes pueden crear un cifrado mas complicado yo solo muestro uno secillo para este tema, ya que no soy experto en powershell.

bueno empesemos este cifrador cifra archivos texto y binarios este es.


si se que hay formas de cifrar archivos en powershell pero quise crear uno por mi cuenta para el blog y que seden una idea de como funcionan los cifradores y como manipular los archivos binarios y si lo hice sencillo en fin.... por otro lado quise verificar tambien que se puede estar utilizando comandos powershell desde javascript y vbscript, ya que para ejecutar archivos .ps1 se necesitan permisos seguimos.

este es el codigo completo en powershell separado linea por linea para que no se confundan

$Ruta = ruta
$Password = pass

# ===== Generar MD5 de la contraseña =====
$md5 = [System.Security.Cryptography.MD5]::Create()
$passBytes = [System.Text.Encoding]::UTF8.GetBytes($Password)
$hashBytes = $md5.ComputeHash($passBytes)

# ===== Leer archivo en binario =====
$fileBytes = [System.IO.File]::ReadAllBytes($Ruta)

# ===== Aplicar XOR =====
for ($i = 0; $i -lt $fileBytes.Length; $i++) {
    $fileBytes[$i] = $fileBytes[$i] -bxor $hashBytes[$i % 16]
}

# ===== Guardar archivo =====
[System.IO.File]::WriteAllBytes($Ruta, $fileBytes)

ese es el codigo en powershell pero lo uniremos en una sola cadena string para poderlo ejecutar en javascript, asi que les dejo el codigo en html y javascript

<html>
<head>
<title>Cifrador De Archivos</title>
</head>

<body>
<marquee>Cifrador De Archivos By Flamer</marquee><br><br>
<center>
Direccion Del Archivo:<input type="file" id="archivo" size="100"><br><br>
Password:<input type="text" id="pass" size="50" style="text-align:center;"><br><br>
<input type="button" value="Aceptar" onclick="proceso()">
</center>
<script>
function proceso()
{
   var shell=new ActiveXObject("wscript.shell");
   var ruta=document.getElementById("archivo").value;
   var pass=document.getElementById("pass").value;
   
   if ( /['"&|]/.test(pass) )
   {
    alert("Contiene caracteres problemáticos");
   }
   else
   {
      shell.run("powershell $Ruta = '" + ruta + "';$Password = '" + pass + "'; \
      $md5 = [System.Security.Cryptography.MD5]::Create();$passBytes = [System.Text.Encoding]::UTF8.GetBytes($Password); \
      $hashBytes = $md5.ComputeHash($passBytes);$fileBytes = [System.IO.File]::ReadAllBytes($Ruta); \
      for ($i = 0; $i -lt $fileBytes.Length; $i++){$fileBytes[$i] = $fileBytes[$i] -bxor $hashBytes[$i % 16]}; \
      [System.IO.File]::WriteAllBytes($Ruta, $fileBytes)");
	  
	  alert("Proceso Terminado....");
   }
   
}
</script>
</body>
</html>

como ven creamos el archivo con la extencion .hta y su codigo en html que crea el boton y los campos de texto.

en el codigo creamos el objecto shell para poder ejecutar los comandos powershell con el metodo run para hacerlo unimos todo el codigo de powershell con ; y como todo va en una sola linea y quiero que se vea completo y no una linea larga y estensa le agregue un \ al final con un espacio despues del ;

bueno creo que no hay mas que agregar eso es todo saludos Flamer y ya use el codigo en un ejecutable y si funciona