CONNEXION
  • RetourJeux
    • Sorties
    • Hit Parade
    • Les + populaires
    • Les + attendus
    • Soluces
    • Tous les Jeux
    • Gaming
  • RetourActu Gaming
    • News
    • Astuces
    • Tests
    • Previews
    • Toute l'actu gaming
  • RetourBons plans
    • Bons plans
    • Bons plans Smartphone
    • Bons plans Hardware
    • Bons plans Image et Son
    • Bons plans Amazon
    • Bons plans Cdiscount
    • Bons plans Decathlon
    • Bons plans Fnac
    • Tous les Bons plans
  • RetourJVTech
    • Actus High-Tech
    • Intelligence Artificielle
    • Smartphones
    • Mobilité urbaine
    • Hardware
    • Image et son
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTech
  • RetourCulture
    • Actus Culture
    • Culture
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch 2
    • Xbox Series
    • Switch
    • Pokemon pocket
    • FC 25 Ultimate Team
    • League of Legends
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • Switch 2
  • PS4
  • One
  • Switch
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Liste des sujets

[python] exécuter une fonction a partir d'une string

Kickme
Kickme
Niveau 26
15 mai 2018 à 16:31:02

Bonjour, jai mon fichier test.py qui contient une fonction pcv(), dans un autre fichier.py je l'ai import et je peux donc appeler cette fonction en faisant test.pcv().

Maintenant disons que j'ai plusieurs test.py qui contiennent tous une fonction pcv() et que je récupère le nom grace a un input:
donc jai mon code comme ceci: (a savoir que test5.py a été importé aussi)

nom = "test5"
nom.pcv()

Cela ne va pas marcher parce qu'il n'y as pas de nom.py alors que je voudrais juste que ca s’exécute comme ci cetait test5.pcv().

En gros est-ce que c'est possible d'y arriver ? si oui comment.
Merci, j’espère avoir été assez clair :)

Kickme
Kickme
Niveau 26
15 mai 2018 à 17:16:36

Re, prob résolu :


module = __import__(script_name)
func = getattr(module, 'pcv')
fonct = func()

sachant que c'est pour une app flask et que je récupère le script_name dynamiquement dans l'adresse ça résout mon problème et j’évite d'avoir a importer tout mes scripts dans le fichier principal.

godrik
godrik
Niveau 30
15 mai 2018 à 17:53:34

Ca ressemble a une faille de securite en devenir de prendre un parametre en entree qui te dit quelle fonction utilise directement sans aucune verification.

Kickme
Kickme
Niveau 26
15 mai 2018 à 18:06:48

Tu penses ?
voila ma route :


@app.route('/zoro/<script_name>')
def script(script_name):
    try:
        module = __import__(script_name)
        func = getattr(module, 'pcv')
        fonct = func()
    except:
        fonct = "error"        
    return render_template("base.html", script_name=script_name, fonct=fonct)

Car de toute façon si le script_name.py n'est pas présent dans mon répertoire ça ne fera rien a part indiquer une erreur

Kickme
Kickme
Niveau 26
15 mai 2018 à 18:12:45

Je fais ça pour ne pas avoir a ajouter une route pour chaque script, j'upload le fichier.py et le reste est générer tout seul quand je me rends sur la page du script

godrik
godrik
Niveau 30
15 mai 2018 à 20:18:37

bah ca pose des question comme, est ce que je peux arriver a injecter /etc/passwd.
Si il y a une autre faille qui me permet d'ecrire mon propre fichier.py, est ce que ce n'est pas un vecteur pour le faire executer?
Est ce que ce n'est pas une facon de permettre a un attaqueur de tester l'existance d'un fichier?

blackapplex
blackapplex
Niveau 10
15 mai 2018 à 22:42:04

C'est effectivement une mauvaise pratique de laisser l'utilisateur choisir les scripts qu'il utilise à partir d'une route.
Suffit que t'ais un script qui est pas censé être accessible ou qui contienne une faille pour poser un soucis.
Ca te force à anticiper tous les cas d'usages, toutes les entrées utilisateur possible ce qui au final revient au même contrainte qu'en passant par une autre méthode ou/et en spécifiant à la main les scripts possibles d'accès.
Après...la sécurité c'est toujours une affaire de moyen et de motivation, je pense pas que tu sois en train de coder une interface web de lancement de missile

Message édité le 15 mai 2018 à 22:42:16 par blackapplex
Sous forums
  • Aide à l'achat Mac
  • Macintosh
  • Création de Jeux
  • Programmation
  • Création de sites web
  • Linux
  • Internet
  • Steam Deck
  • Hardware
La vidéo du moment