Maison >développement back-end >Tutoriel Python >Comment exécuter en toute sécurité des scripts Python nécessitant des privilèges élevés sans mots de passe codés en dur ?
Utilisation de sudo avec un script Python : alternatives sécurisées aux mots de passe codés en dur
Vous essayez de créer un script Python qui monte un dossier partagé VirtualBox sur exécution. Cependant, cela nécessite des privilèges élevés, ce qui vous amène à explorer des options telles que l'exécution du script en tant que sudo ou l'utilisation de sudo dans le script.
Bien que fournir votre mot de passe dans un fichier .py ne soit certainement pas recommandé, cela peut être acceptable. pour une machine virtuelle peu critique. Cependant, la solution que vous proposez suscite des inquiétudes :
#!/usr/bin/env python import subprocess sudoPassword = 'mypass' command = 'mount -t vboxsf myfolder /home/myuser/myfolder' subprocess.Popen('sudo -S' , shell=True,stdout=subprocess.PIPE) subprocess.Popen(sudoPassword , shell=True,stdout=subprocess.PIPE) subprocess.Popen(command , shell=True,stdout=subprocess.PIPE)
Cette approche est fortement déconseillée. Le codage en dur des mots de passe est considéré comme une mauvaise pratique de sécurité, laissant votre système vulnérable aux accès non autorisés.
Alternatives au codage en dur des mots de passe
Heureusement, il existe des alternatives plus sécurisées :
Ces alternatives vous permettent d'atteindre votre objectif sans compromettre la sécurité de votre système. Des lectures plus approfondies sur ces sujets peuvent fournir des informations plus approfondies.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!