Maison > Java > javaDidacticiel > Comment exécuter des commandes Bash avec les privilèges Sudo en Java malgré les limitations de ProcessBuilder ?

Comment exécuter des commandes Bash avec les privilèges Sudo en Java malgré les limitations de ProcessBuilder ?

Mary-Kate Olsen
Libérer: 2024-10-24 11:36:29
original
978 Les gens l'ont consulté

How to Execute Bash Commands with Sudo Privileges in Java Despite ProcessBuilder Limitations?

Exécuter des commandes Bash avec les privilèges Sudo en Java

ProcessBuilder fournit une méthode pratique pour exécuter des commandes bash. Cependant, lorsque vous tentez d'exécuter des commandes nécessitant des privilèges de superutilisateur, cela peut ne pas suffire. Cet article explique comment transmettre efficacement un mot de passe de superutilisateur aux commandes bash à l'aide de Java.

Dans l'extrait de code fourni, l'intention est d'exécuter la commande "gedit" en utilisant les privilèges sudo. Bien que l'approche utilisant "gksudo" puisse ne pas être réalisable en raison de sa dépréciation, une solution alternative est présentée.

Présentation de l'approche proposée

Remarque : Cette approche n'est pas recommandé pour une utilisation en production en raison de problèmes de sécurité.

La solution proposée implique l'exécution d'une série de commandes à l'aide de Runtime.getRuntime().exec() :

  1. Le shell bash est invoqué avec l'option "-c" pour exécuter une commande ultérieure.
  2. La commande souhaitée, dans ce cas "ls", est préfixée par un tube "|".
  3. À l'intérieur du tube, la chaîne "mot de passe" est transmis en entrée à la commande "echo".
  4. La sortie de la commande "echo" est transmise à la commande "sudo -S", qui utilise le mot de passe fourni pour exécuter le "ls". commande avec des privilèges élevés.

Exemple de code

<code class="java">public static void main(String[] args) throws IOException {

    String[] cmd = {"/bin/bash","-c","echo password| sudo -S ls"};
    Process pb = Runtime.getRuntime().exec(cmd);

    String line;
    BufferedReader input = new BufferedReader(new InputStreamReader(pb.getInputStream()));
    while ((line = input.readLine()) != null) {
        System.out.println(line);
    }
    input.close();
}</code>
Copier après la connexion

Utilisation et mises en garde

Cette approche suppose que le "mot de passe" fourni est le mot de passe sudo correct. Il est essentiel de faire preuve de prudence lors de l’utilisation de cette technique en raison des risques potentiels pour la sécurité. Évitez de stocker les mots de passe en texte brut et envisagez des solutions alternatives pour les opérations sensibles.

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!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal