• STATISTIQUES
  • Il y a eu un total de 0 membres et 58480 visiteurs sur le site dans les dernières 24h pour un total de 58 480 personnes!
    Membres: 2 605
    Discussions: 3 579
    Messages: 32 816
    Tutoriels: 78
    Téléchargements: 38
    Sites dans l'annuaire: 58


  • ANNUAIRE
  • [FR] Zenk-Security
    La communauté zenk-security a pour objet principal la sécurité informatique, nous sommes des tou...
    Hacking
    [EN] Reddit
    Subreddit dédié à la sécurité informatique.
    Hacking
    [EN] Security Traps
    Site de challenge qui prétend être construit non pas dans le but de parfaire vos connaissances, mais plutôt dan...
    Challenges
    [EN] Exploit-db
    Une base de données d'exploits triés par genre (GHDB, Remote, Local, Web, DOS, ShellCode) à ...
    Vulnérabilités
    [FR] Newbie Contest
    Crackme: 35, Cryptographie: 49, Hacking: 27, Javascript/Java: 17, Logique: 31, Programmation: 23, Stéganographie: 53
    Challenges
    [EN] This is legal
    Basic: 10, Realistic: 5, Programming: 1, Bonus: 11, SQL: 2, Encryption: 6, Application: 4, User Contributed: 3
    Challenges
    [EN] Big-Daddy
    Big-Daddy est site internet communautaire avec un effectif diversifié, y compris des artistes, des programmeur...
    Hacking

  • DONATION
  • Si vous avez trouvé ce site internet utile, nous vous invitons à nous faire un don du montant de votre choix via Paypal. Ce don servira à financer notre hébergement.

    MERCI!




Note de ce sujet :
  • Moyenne : 0 (0 vote(s))
  • 1
  • 2
  • 3
  • 4
  • 5
Crunch -> Pattern
03-10-2016, 13h54
Message : #1
EvaExe Hors ligne
Newbie
*



Messages : 9
Sujets : 3
Points: 2
Inscription : Sep 2016
Crunch -> Pattern
Bonjour a vous,

je feuillette internet depuis quelques heures déja, mais je n'ai pas trouvé de réponse claire a ma question, et le man de crunch..bha j'ai du mal

C'est tres simple,

Je souhaite généré un dico, (evidement..)
cependant je veut qu'il respect un pattern précit,

XXXX XXXX XX XXXX

ou X est un char alphanumerique A-A a-a 0-9 en respectant les " " espace
Est ce que qulqu'un aurait une piste ?

Grand merci,
+1 (0) -1 (0) Répondre
03-10-2016, 16h34
Message : #2
EvaExe Hors ligne
Newbie
*



Messages : 9
Sujets : 3
Points: 2
Inscription : Sep 2016
RE: Crunch -> Pattern
Apres encore quelques recherches, et discutions sur IRC,
je vais me lancer dans la création de ce script.
+1 (0) -1 (0) Répondre
03-10-2016, 16h54 (Modification du message : 03-10-2016, 20h16 par b0fh.)
Message : #3
b0fh Hors ligne
Membre actif
*



Messages : 210
Sujets : 17
Points: 309
Inscription : Jul 2012
RE: Crunch -> Pattern
Code HASKELL :
import Control.Monad
import System.Environment

charmap '@' = ['a'..'z']
charmap '%' = ['0'..'9']
charmap '^' = ['!'..'/'] ++ [':'..'@'] ++ ['['..'`']
charmap ',' = ['A'..'Z']
charmap  x  = [x]

main = getArgs >>= mapM_ (mapM_ putStrLn . mapM charmap)


Code :
ghc -O3 --make gogole.hs

Code :
$ ./gogole --@--
--a--
--b--
--c--
...

Code :
$ ./gogole @%@
a0a
a0b
...
a0z
a1a
a1b
...

(Edité pour accepter plusieurs patterns en argument)
+1 (1) -1 (0) Répondre
03-10-2016, 17h57 (Modification du message : 03-10-2016, 18h01 par EvaExe.)
Message : #4
EvaExe Hors ligne
Newbie
*



Messages : 9
Sujets : 3
Points: 2
Inscription : Sep 2016
RE: Crunch -> Pattern
Merci pour l'info !!
Jvais d'ab essayer de créer un script en C pour faire le job,
mais je pense que ton idée sera bien meilleur, Smile
je testerais les deux

Je vient de faire un petit bout de code,
pour une clef a 5 Variable pouvant prendre 256 valeurs chacune
je débute, ALORS ON NE SE MOQUE PAS !!! hain !

Code :
char key0[4];
char key1[4];
char key[4];
char key[4];
int cpt0=0;
int cpt1=0;
int cpt2=0;
int cpt3=0;
int cpt4=0;
char allval[256]; //Contient tout les char alphanumerique (unique)
while !end {
//teste une a une toute les combinaisons possible
if (cpt0 >= 256)
    {
    cpt0=0;
    cpt1++;
    }else{
if (cpt1 >= 256)
    {
    cpt1=0;
    cpt2++;
    }else{
if (cpt2 >= 256)
    {
    cpt2=0;
    cpt3++;
    }
    }else{
if (cpt4 >= 256)
    {
    cpt3=0;
    cpt4++:
    }else{
if (cpt4 >= 256){
    end=true;
}
cpt0++;
}
//Insertion du char unique dans chaque case
key[o]=alval[cpt0];
key[1]=alval[cpt1];
key[2]=alval[cpt2];
key[3]=alval[cpt3];
key[4]=alval[cpt4];
//return les char testé
cout>>key[0],key[1],key[2],[key3],key[4];
}
+1 (1) -1 (0) Répondre
03-10-2016, 18h01
Message : #5
supersnail Hors ligne
Éleveur d'ornithorynques
*******



Messages : 1,609
Sujets : 71
Points: 465
Inscription : Jan 2012
RE: Crunch -> Pattern
Je crois que ton code ne compile pas :')

Sinon quitte à faire du C++ (coucou "cout" :>), autant utiliser std:Confusedtring plutôt que des tableaux de char. Et au passage, je vois pas trop quel algorithme t'essaies d'implémenter pour le coup.

PS: essaie d'indenter ton code, c'est plus facile à lire pour nos yeux :p
Mon blog

Code :
push esp ; dec eax ; inc ebp ; and [edi+0x41],al ; dec ebp ; inc ebp

"VIM est merveilleux" © supersnail
+1 (0) -1 (0) Répondre
03-10-2016, 18h05
Message : #6
EvaExe Hors ligne
Newbie
*



Messages : 9
Sujets : 3
Points: 2
Inscription : Sep 2016
RE: Crunch -> Pattern
En fait je voudrais créer une chaine de caractère de longeur 5 char qui prend tour a tour toute les valeurs possible sans redondances
ex :
aaaaa
baaaa
bbaaa
.....
zUw*9

Un algo de brute force pour faire simple;
je vais regarder std:Confusedtring

merci,
+1 (0) -1 (0) Répondre
03-10-2016, 18h11 (Modification du message : 04-10-2016, 15h28 par notfound.)
Message : #7
notfound Hors ligne
#!/usr/bin/env bash
*



Messages : 687
Sujets : 47
Points: 271
Inscription : Sep 2012
RE: Crunch -> Pattern
Un petit bout de code en C, en récursif.
Ça faisait un bail que j'avais pas codé en C et j'avoue avoir galérer, donc ça vaut ce que ça vaut Smile

[spoiler]
>>> gcc crunch_is_not_a_chocolat.c -o CRU -O3 ; time ./CRU 5 5 > /dev/null

real 0m0.712s
user 0m0.710s
sys 0m0.000s

Code C :

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

static const char charset[] =
        "abcdefghijklmnopqrstuvwxyz";
//      "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
//      "0123456789";

void dict(char *word, int index, int max_local);


int maxlen;
int main(int argc, char **argv){
    int i = atoi(argv[1]);
    maxlen = atoi(argv[2]);
    char *buf = malloc(maxlen + 1);
    for (i ; i <= maxlen; ++i){
        memset(buf, 0, maxlen + 1);
        dict(buf, 0, i);
    }
    free(buf);
    return 0;
}


void dict(char *word, int index, int max_local){
        int i;
        const int sizeCharset = sizeof(charset);
        for ( i=0 ; i<sizeCharset-1 ; ++i){
            word[index] = charset[i];
            if (index == max_local - 1){
                printf("%s\n", word);
                if (max_local == maxlen+1) exit(0);
            }
            else dict(word, index + 1, max_local);
        }
}
 

[/spoiler]
+1 (2) -1 (0) Répondre
03-10-2016, 19h49 (Modification du message : 03-10-2016, 19h56 par EvaExe.)
Message : #8
EvaExe Hors ligne
Newbie
*



Messages : 9
Sujets : 3
Points: 2
Inscription : Sep 2016
RE: Crunch -> Pattern
Voila, j'ai fais un code lent mais fonctionelle,
J'ai absolument voullut terminer mon travaille avant de m'inspirer du votre Smile
En tout cas merci,
[spoiler]
Code C :

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
using namespace std;

int main(void)
{
    bool end=false;
    int cpt0=-1;
    int cpt1=0;
    int cpt2=0;
    int cpt3=0;
    int cpt4=0;
    char key[5];
    static const char charset[] =
        "abcdefghijklmnopqrstuvwxyz";
    while (!end)
    {
//teste une a une toute les combinaisons possible
        if (cpt0 >= 27)
        {
            cpt0=0;
            cpt1++;
        }
        else
        {
            cpt0++;
        };

        if (cpt1 >= 27)
        {
            cpt1=0;
            cpt2++;
        }

        if (cpt2 >= 27)
        {
            cpt2=0;
            cpt3++;
        }

        if (cpt3 >= 27)
        {
            cpt3=0;
            cpt4++;
        }

        if (cpt4 >= 27)
        {
            end=true;
        };

/*Insertion du char unique dans chaque case*/
        key[0]=charset[cpt0];
        key[1]=charset[cpt1];
        key[2]=charset[cpt2];
        key[3]=charset[cpt3];
        key[4]=charset[cpt4];

        cout<<key[0]<<key[1]<<key[2]<<key[3]<<key[4]<<endl;
    };
};


 

[/spoiler]
+1 (1) -1 (0) Répondre
04-10-2016, 00h37
Message : #9
EvaExe Hors ligne
Newbie
*



Messages : 9
Sujets : 3
Points: 2
Inscription : Sep 2016
RE: Crunch -> Pattern
Nous voici enfin sur la ...fin
J'ai finalisé le script, optimisé (je crois xD)
J'ai pu le pipe avec aircrack, (merci a gruik)
il faut que le script sorte en cout ou stdout ect..

Du coup, je le poste, même si c'est nul, je suis fier de mwa !

Le script genere 18char alphanumérique pour creer une clef unique a chaque foi.
Il suit le pattern suivant XXXX XXXX XXXX XX

[spoiler]
Code C :

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
using namespace std;

int main(void)
{
     static const char charset[] =
        "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
    int cpt[19];
    bool end=false;
    int x;

    for(x=0; x<19; x++)
    {
        cpt[x]=0;
    };


    while (!end)
    {
//teste une a une toute les combinaisons possible
        if (cpt[0] >= 64)
        {
            cpt[0]=0;
            cpt[1]++;
            if (cpt[1] >= 64)
            {
                cpt[1]=0;
                cpt[2]++;


                if (cpt[2] >= 64)
                {
                    cpt[2]=0;
                    cpt[3]++;


                    if (cpt[3] >= 64)
                    {
                        cpt[3]=0;
                        cpt[4]++;
                        if (cpt[4] >= 64)
                        {
                            cpt[4]=0;
                            cpt[5]++;
                            if (cpt[5]>=64)
                            {
                                cpt[5]=0;
                                cpt[6]++;
                                if(cpt[6]>=64)
                                {
                                    cpt[6]=0;
                                    cpt[7]++;
                                    if(cpt[7]>=64)
                                    {
                                        cpt[7]=0;
                                        cpt[8]++;

                                        if(cpt[8]>=64)
                                        {
                                            cpt[8]=0;
                                            cpt[9]++;
                                            if(cpt[9]>=64)
                                            {
                                                cpt[9]=0;
                                                cpt[10]++;
                                                if(cpt[10]>=64)
                                                {
                                                    cpt[10]=0;
                                                    cpt[11]++;
                                                    if(cpt[11]>=64)
                                                    {
                                                        cpt[11]=0;
                                                        cpt[12]++;
                                                        if(cpt[12]>=64)
                                                        {
                                                            cpt[12]=0;
                                                            cpt[13]++;
                                                            if(cpt[13]>=64)
                                                            {
                                                                cpt[13]=0;
                                                                cpt[14]++;
                                                                if(cpt[14]>=64)
                                                                {
                                                                    cpt[14]=0;
                                                                    cpt[15]++;

                                                                    if(cpt[15]>=64)
                                                                    {
                                                                        cpt[15]=0;
                                                                        cpt[16]++;
                                                                        if(cpt[16]>=64)
                                                                        {
                                                                            cpt[16]=0;
                                                                            cpt[17]++;
                                                                            if(cpt[17]>=64)
                                                                            {
                                                                                cpt[17]=0;
                                                                                cpt[18]++;

                                                                                if(cpt[18]>=64)
                                                                                {
                                                                                    end=true;
                                                                                }
                                                                            }
                                                                        }
                                                                    }
                                                                }
                                                            }
                                                        }
                                                    }
                                                }
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }



            else
            {
                cpt[0]++;
            };




            cout<<charset[cpt[0]]<<charset[cpt[1]]<<charset[cpt[2]]<<charset[cpt[3]]<<' '
                <<charset[cpt[4]]<<charset[cpt[5]]<<charset[cpt[6]]<<charset[cpt[7]]<<' '
                <<charset[cpt[8]]<<charset[cpt[9]]<<charset[cpt[10]]<<charset[cpt[11]]<<' '
                <<charset[cpt[12]]<<charset[cpt[13]]<<charset[cpt[14]]<<charset[cpt[15]]<<' '
                <<charset[cpt[16]]<<charset[cpt[17]]<<endl;

};
};
 

[/spoiler]
+1 (0) -1 (0) Répondre


Atteindre :


Utilisateur(s) parcourant ce sujet : 1 visiteur(s)
N-PN
Accueil | Challenges | Tutoriels | Téléchargements | Forum | Retourner en haut