IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

expressions régulières à appliquer.


Sujet :

Python

  1. #1
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut expressions régulières à appliquer.
    Bonsoir,
    Pourriez vous m'aider s'il vous plait, Quelle est l’expression régulière en python de ces réglés (phrases) ?
    rule = ' alert tcp 10.0.02 any -> 10.0.0.1 80 '
    rule = ' log tcp 10.0.02 any -> 10.0.0.1 21 '
    Je vous remercie d'avance

  2. #2
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    c'est urgent aidez moi SVP
    Ce n'est jamais une bonne façon de poser une question.

    Salut,

    Bienvenue dans le forum Python.

    Ta question est donc:
    Quelle est l’expression régulière en python de ces réglés (phrases) ?
    rule = ' alert tcp 10.0.02 any -> 10.0.0.1 80 '
    rule = ' log tcp 10.0.02 any -> 10.0.0.1 21 '
    Hélas, un réglé ne fait pas partie du jargon Python.

    Que veux-tu faire, d'où sortent ces deux lignes de code ?

  3. #3
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    je me suis trompé désolé,je voulais dire ces règles et pour votre question je veux ouvrir un fichier.txt avec ex : alerts = open("signature.txt", "r") et ce fichier contient des régles je veux les analysées (ce sont des régles pour un ids intrusion detection system)

  4. #4
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    le fichier signature.txt contient des régles (C'est du texte) , Il faut pouvoir les lire et les décoder avec Python c'est çà le problème et c pour cela j'ai pensé a les expression régulières !

  5. #5
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    salut,

    je pense qu'une bonne recherche te donnera des résultats plus probants

  6. #6
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    Merci a vous ! j'ai fait cette recherche et j'ai pas trouvé l’objectif recherché

  7. #7
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Pourtant, il y a un exemple taillé sur mesure pour toi:
    https://www.snip2code.com/Snippet/80...to-Python-Dict

  8. #8
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    Bonjour, je travail sur cet exemple et c'est pour ça je cherche l'expression régulière de cette ligne rule = 'alert tcp 10.0.0.1 any -> 10.0.0.2 80 ' car j'ai modifie l'exemple
    Merci bcp pour votre aide

  9. #9
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    Citation Envoyé par sarah sarita Voir le message
    je cherche l'expression régulière de cette ligne rule = 'alert tcp 10.0.0.1 any -> 10.0.0.2 80 '
    en voilà une : ^.*$, des précisions à apporter sur ce que tu cherches à faire très concrètement ?

  10. #10
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Citation Envoyé par sarah sarita Voir le message
    Bonjour, je travail sur cet exemple et c'est pour ça je cherche l'expression régulière de cette ligne rule = 'alert tcp 10.0.0.1 any -> 10.0.0.2 80 ' car j'ai modifie l'exemple
    Merci bcp pour votre aide
    Dans le code qui vous a été signalé par VinsS, l'expression régulière est r'(^.+)\((.+)\).
    Le développeur considère qu'une ligne est de la forme "HEADER ( OPTIONS )".
    L'expression régulière sert à récupérer HEADER et OPTIONS traitées ensuite à coups de simples "split".
    Et au final çà retourne un dictionnaire sur lequel on peut travailler.

    Ce n'est peut être pas ce que vous vouliez mais avez vous formulé autre chose?

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  11. #11
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    Oui, je veux prendre que la partie header

  12. #12
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    d’après la réponse de @BufferBob la réponse sera normalement : res = re.search(r' (^.*$)', line)

  13. #13
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    c'est quoi le header dans la ligne rule = 'alert tcp 10.0.0.1 any -> 10.0.0.2 80 ' ?

  14. #14
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    alert tcp 10.0.0.1 any -> 10.0.0.2 80

  15. #15
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    je te propose celle-ci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    res = re.search('^rule\s*=\s*[\'\"](.+?)\s*[\'\"]\s*$', line)
    header = res.group(1)

  16. #16
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Et moi celle-ci...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    >>> line = "rule = alert tcp 10.0.0.1 any -> 10.0.0.2 80"
    >>> line.split(' = ')[1]
    "alert tcp 10.0.0.1 any -> 10.0.0.2 80"
    >>>
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  17. #17
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    je vous remercie infiniment,
    et concernant ce que je suis entrain de faire est d'implémenter un IDS dans l'environnement SDN sous Mininet et avec OpenFlow et POX contrôleur et mon programme ouvre un fichier.txt contient les signatures de SNORT (des régles) et apres l'ouverture, voire la correspondance avec les packets entrants et les signatures si c'est oui il affiche un msg d'alert et génére un fichier log ( outFile) la ou je stocke les informations sur les paquets suspects (détectés par l'DS) comme l'heure, l'entête du paquets, etc.

  18. #18
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    pourriez vous me voir mon script et me dire ou est le problème SVP , (je vous ai expliqué ce que je suis entraine de faire)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    import os 
    import sys
    import re
    def readFile():
     
           # read txt file
           # FILE CONTIENT:
           #rule = ' alert tcp 10.0.0.2 any -> 10.0.0.1 80 '
           #rule = ' log tcp 10.0.0.2 any -> 10.0.0.1 21 
     
           signature = raw_input('Enter the name of the txt file please :')+'.txt'# Name of text file coerced with +.txt
           try:
               alerts = open("signature.txt", "r")
    	   #print(signature.txt ,alerts)
           except:
               print "Le fichier", signature, "est introuvable"
     
           if type(lines) != list:
              res = re.search('^rule\s*=\s*[\'\"](.+?)\s*[\'\"]\s*$', line)
     
           #make dictionnary
           header = res.group(1)
           #Traiter lentete en divisant lespace
           headers = header.split()
           print("headers")
     
           rule = {
                    'actions':headers[0],
                    'protocol':headers[1],
                    'nw_src':headers[2],
                    'in_port':headers[3],
                    'direction':headers[4],
                    'nw_dst':headers[5],
                    'out_port':headers[6],
     
                    }
     
           #je veux voir la coresspondance entre les packets entrants et les signatures dans le fichier.txt, je sais pas si c juste ou pas !
           for line in alerts.lines :
              f = rule.match(line)
              if f.match.headers[0]==alert and f.match.headers[1]== Ethp("tcp ")and f.match.f.match.headers[2]==IPAddr("10.0.0.2") and f.match.headers[3]=='any' and f.match.headers[5]==IPAddr("10.0.0.1")and f.match.headers[6]==80 :
                 print ('Verifier votre fichier log pour voir la detection ')
    	     alerts.close()
     
                with open ("detection.log","a") as a :
    # il faut ecrire dans le fichier.log: @ip et le numero de port source et lheure par exemple mais je sais pas comment afficher l'heure de la detection 
                a.write("  comment afficher l'heure et l'adresse détecté ici ???? ")
                a.close()
    readFile()

  19. #19
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Citation Envoyé par sarah sarita Voir le message
    pourriez vous me voir mon script et me dire ou est le problème SVP
    Python doit vous afficher un message d'erreur indiquant déjà où est le problème... et quel est le problème: "NameError".

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  20. #20
    Membre à l'essai
    Femme Profil pro
    étudiante
    Inscrit en
    Janvier 2016
    Messages
    54
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : étudiante

    Informations forums :
    Inscription : Janvier 2016
    Messages : 54
    Points : 21
    Points
    21
    Par défaut
    des explications SVP ?!

Discussions similaires

  1. [RegEx] Comment appliquer une condition à une expression régulière ?
    Par Maxiglider dans le forum Langage
    Réponses: 2
    Dernier message: 01/12/2015, 20h46
  2. Expression réguliére
    Par Mad_Max dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 16/09/2003, 18h17
  3. [expression régulière] mon cerveau fait des noeuds..
    Par nawac dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 27/05/2003, 10h06
  4. Expressions réguliéres
    Par Tooms dans le forum Langage
    Réponses: 4
    Dernier message: 06/12/2002, 18h42
  5. Réponses: 5
    Dernier message: 11/06/2002, 15h21

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo