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

 

 


Tema destacado: Arreglado, de nuevo, el registro del warzone (wargame) de EHN


+  Foro de elhacker.net
|-+  Programación
| |-+  Ingeniería Inversa (Moderadores: karmany, .:UND3R:., MCKSys Argentina)
| | |-+  Crack winrar password conociendo parte de la contraseña
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: Crack winrar password conociendo parte de la contraseña  (Leído 4,794 veces)
AngelFire

Desconectado Desconectado

Mensajes: 118


WTF :)


Ver Perfil WWW
Crack winrar password conociendo parte de la contraseña
« en: 1 Junio 2023, 17:50 pm »

Buenas. Lo que sucede es lo siguiente, tengo un winrar el cual le puse contraseña y solo recuerdo como termina. Como los caracteres olvidados son inferiores a 6, quisera saber como puedo hacer fuerza bruta manteniendo el final de la contraseña.
Ejemplo
Contraseña: xxxxxx08574

O sea los numeros finales se mantienen, exites ya algun software que permita eso o hay que irse a python.

Gracias por la lectura asi como por cualquier comentario de antemano.

Como se puede mejorar esta variante?

Código:
import os
Alphabets = "0123456789"
B = '050678844'
for a in range(0,10):
 for b in range(0,10):
  for c in range(0,10):
    for d in range(0,10):
        Brute = Alphabets[a] + Alphabets[b] + Alphabets[c] + Alphabets[d] + B
        os.popen("Rar.exe x -p" + Brute + " CI_XXXXXXXX78844.rar")
        print (str(Brute))
#   raw_input()
raw_input("Done !")
« Última modificación: 1 Junio 2023, 18:24 pm por AngelFire » En línea

MCKSys Argentina
Moderador Global
***
Desconectado Desconectado

Mensajes: 5.524


Diviértete crackeando, que para eso estamos!


Ver Perfil
Re: Crack winrar password conociendo parte de la contraseña
« Respuesta #1 en: 1 Junio 2023, 23:19 pm »

Hola!

Como se puede mejorar esta variante?

Una variante sin tener que usar range:

Código:
import os
Alphabets = "0123456789"
B = '050678844'
for a in Alphabets:
 for b in Alphabets:
  for c in Alphabets:
    for d in Alphabets:
        Brute = a + b + c + d + B
        os.popen("Rar.exe x -p" + Brute + " CI_XXXXXXXX78844.rar")
        print (str(Brute))
#   raw_input()
raw_input("Done !")

Saludos!
En línea

MCKSys Argentina

"Si piensas que algo está bien sólo porque todo el mundo lo cree, no estás pensando."

AngelFire

Desconectado Desconectado

Mensajes: 118


WTF :)


Ver Perfil WWW
Re: Crack winrar password conociendo parte de la contraseña
« Respuesta #2 en: 3 Junio 2023, 00:16 am »

En el siguiente codigo si se extiende algo como:

Código:
for a in Alphabets:
    for b in Alphabets:
        for c in Alphabets:
            for d in Alphabets:
                for e in Alphabets:
                    for f in Alphabets:
                        for g in Alphabets:
                            for h in Alphabets:
Terminan abriendose suficientes procesos como para colgar el ordenador. No veo como solucionarlo con os.close, alguna recomendación, para correr todo el proceso sin colgar el ordenador.

Gracias y saludos.
« Última modificación: 3 Junio 2023, 00:37 am por AngelFire » En línea

Danielㅤ


Desconectado Desconectado

Mensajes: 1.853


🔵🔵🔵🔵🔵🔵🔵


Ver Perfil
Re: Crack winrar password conociendo parte de la contraseña
« Respuesta #3 en: 3 Junio 2023, 01:35 am »

Hola, en el código por lo que veo las variables a, b, c y d tienen todas el mismo valor ya que en cada for vuelve cada variable a empezar de cero el bucle por lo que todas terminan teniendo el mismo valor, de todas maneras hay mejores formas para lograr eso, siempre se recomienda aprovechar un bucle para usarlo con otras iteraciones.

Por otro lado se debería trabajar con threads (multi hilos) usando el método  join() para que el programa pueda trabajar por separado y no saturarse.


Saludos
« Última modificación: 3 Junio 2023, 01:37 am por Danielㅤ » En línea

AngelFire

Desconectado Desconectado

Mensajes: 118


WTF :)


Ver Perfil WWW
Re: Crack winrar password conociendo parte de la contraseña
« Respuesta #4 en: 3 Junio 2023, 01:53 am »

Chatgpt:
Para garantizar que el proceso unrar se complete correctamente antes de continuar con la siguiente iteración del bucle, puedes utilizar subprocess en lugar de os.popen(). La función subprocess.run() espera a que el proceso se complete antes de continuar con el código

Asi va ok, puden probar con un winrar que llamen test.rar y una contraseña de 3 digitos que terminen en 3 por ejemplo:

Código:
003
013
023
033
043
053
063
073
083
093
103
113
123
203
213
223
233
243
253
263
273
283
293
303
313
323
333
343
353
363
373
383
393
403
413
423
433
443
453
463
473
483
493
503
513
523
533
543
553
563
573
583
593
603
613
623
633
643
653
663
673
683
693
703
713
723
733
743
753
763
773
783
793
803
813
823
833
843
853
863
873
883
893
903
913
923
933
943
953
963
973
983
993

Código:
import subprocess
Alphabets = "0123456789"
B = '3'
for a in Alphabets:
 for b in Alphabets:
    Brute = a + b + B
    process = subprocess.run(["unrar.exe", "x", "-p" + Brute, "test.rar"])
    print (str(Brute))
    if process.returncode == 0:
        break

El tema es como seria para evitar todas las salidas fallidas de errores tipo:
Código:
UNRAR 6.21 x64 freeware      Copyright (c) 1993-2023 Alexander Roshal


Extracting from test.rar

Total errors: 1
« Última modificación: 3 Junio 2023, 01:57 am por AngelFire » En línea

AngelFire

Desconectado Desconectado

Mensajes: 118


WTF :)


Ver Perfil WWW
Re: Crack winrar password conociendo parte de la contraseña
« Respuesta #5 en: 3 Junio 2023, 02:09 am »

Respuesta final ya manejando las salidas de unrar. Aporte Chatgpt

Código:
import subprocess
Alphabets = "0123456789"
B = '3'
for a in Alphabets:
    for b in Alphabets:
        Brute = a + b + B
        print (str(Brute))
        process = subprocess.run(["unrar.exe", "x", "-p" + Brute, "test.rar"],
        stdout=subprocess.PIPE, stderr=subprocess.PIPE)
        stdout = process.stdout.decode()  # Salida estándar del proceso
        stderr = process.stderr.decode()  # Salida de error del proceso

        if "Total errors" not in stdout:
            print("Contraseña encontrada:", Brute)
            break
« Última modificación: 3 Junio 2023, 02:15 am por AngelFire » En línea

D3s0rd3n

Desconectado Desconectado

Mensajes: 97


Tu Mente es mi arma. Entregame tu mente


Ver Perfil
Re: Crack winrar password conociendo parte de la contraseña
« Respuesta #6 en: 12 Noviembre 2023, 19:08 pm »

Se me hace Bien que quieres hacer las cosas por tu cuenta y que bueno que tengas la iniciativa de hacer las cosas.

Habiendo dicho eso tu Codigo es muy ineficiente, Al igual que algunos que eh visto en Las respiestas de chatgpt. Quisiera ser mejor programador para explicarte la mejor manera de hacerlo. Pero a veces, y mas en Este tipp de casos es mejor no reinventar la rueda y tomar lo que ya existe. Dicho esto tu mejor opcion hasta donde yo se es  usar una combinacion de crunch con John the ripper.

Crunch es muy rapido para generar diccionarios. En tu Caso especifico seria Algo como :

Código:
crunch 11 11 -t @@@@@@08574 -o crackrar.txt

Esto genera una lista de minimi 11 caracteres y maximo 11 caracteres terminando en 08754.

John the ripper es mejor por que no tienes que empezar un proceso Nuevo para cada intento. Esto es muy intensivo para los recursos y aumenta El tiempo exponencialmente con la mayor cantidad de claves a intentar. Con John puedes obtener un hash del archivo y crackear el  hash sin tener que montar El programa de rar para cada intento. Para esto necesitas rar2john lo que se veria Algo como:

Código:
rar2john archivoencryptado.rar > hash

Esto genera El hash de tu archivo y lo Guarda en un archivo nombrado "hash" (o lo que tu quieres). Despues usa jtr para crackearlo:

Código:
john hash -w crackrar.txt

Y pues si es cierto tu formato deberias tener tu clave.

Si tienes mas informacion sobre tu clave seria mejor. Como por ejemplo.si sabes que no hay caracteres que se repiten 3 veces como "aaa" o "333" o sis sabes que clave no tiene caracteres especiales o mayusculas etc. Esto reduce Bastante El tamaño de tu diccionario y por ende El tiempo que tardas en crackear.

A mi me gusta jtr pero tambien puedes usar hascat (especialmente si tienes gpu). Me parece que Seria usar -m 12500 pero no se. Seria buscarlo en la documentacion. Espero que te ayude esto.
En línea

Gobiernos del Mundo Industrial, ustedes, cansados gigantes de carne y acero
vengo del Ciberespacio, el nuevo hogar de la Mente. En nombre del futuro, les
pido en el pasado  que nos dejen en paz.  No son  bienvenidos entre nosotros.
No tienen ninguna soberania sobre el lugar donde nos reunimos.
Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Programa para recuperar password de winrar
Software
tordoman 8 3,540 Último mensaje 18 Enero 2013, 23:09 pm
por тαптяα
WINRAR PASSWORD CRACKER
Criptografía
night.hawk 9 8,847 Último mensaje 2 Noviembre 2014, 00:59 am
por engel lex
[Download] Winrar password bypass.
Software
nevachana 0 1,562 Último mensaje 18 Agosto 2015, 21:53 pm
por nevachana
MOVIDO: [Download] Winrar password bypass.
Software
Eleкtro 0 1,576 Último mensaje 19 Agosto 2015, 03:30 am
por Eleкtro
WINRar Password Cracker V1.0
Software
0b1ivi0n 2 5,834 Último mensaje 30 Julio 2016, 23:57 pm
por Eleкtro
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines