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

Linux Discussion :

Difficulté mise en oeuvre sudo - ligne de commande sqlplus dans une page php


Sujet :

Linux

  1. #1
    Futur Membre du Club
    Inscrit en
    Juin 2007
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 37
    Points : 9
    Points
    9
    Par défaut Difficulté mise en oeuvre sudo - ligne de commande sqlplus dans une page php
    un souci pour configurer / mettre en oeuvre correctement sudo

    pour commencer description succinte de ma machine:
    Debian GNU/Linux 6.0
    Linux 2.6.32-5-amd64
    et
    PHP Version 5.3.3-7+squeeze15

    je souhaite utiliser sudo pour pouvoir executer une requête (avec paramètres) contenant un spool pour creation de fichier vers ma machine,
    selon le code php suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    <?php
    ORACLE_HOME='/usr/lib/oracle/11.2/client/bin';
    shell_exec('export $ORACLE_HOME');
    SQLPATH=$ORACLE_HOME/'sqlplus';
    shell_exec('export $SQLPATH');
    PATH=$ORACLE_HOME:$PATH;
    shell_exec('export $PATH');
     
    $strcmd='sudo sqlplus login/pw//x.x.x.x:1524/InstanceDeBase @/rep/requeteSql.sql param1 param2';
    shell_exec($strcmd);
     
    ?>
    paramètrage de sudo dans ma machine:

    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
     
    # /etc/sudoers
    #
    # This file MUST be edited with the 'visudo' command as root.
    #
    # See the man page for details on how to write a sudoers file.
    #
    #Defaults       env_reset
    Defaults secure_path="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
    # Host alias specification
    # User alias specification
    # Cmnd alias specification
    # User privilege specification
    root    ALL=(ALL) ALL
    www-data ALL=(ALL) NOPASSWD:/usr/bin/sqlplus
     
    # Allow members of group sudo to execute any command
    # (Note that later entries override this, so you might need to move
    # it further down)
    %sudo ALL=(ALL) ALL
    #
    #includedir /etc/sudoers.d
    Ceci fait, je suis désorienté car en mode console, la requete "passe"
    lorsque je transmets au port console loggé user www-data la commande
    sqlplus login/pw//x.x.x.x:1524/InstanceDeBase @/rep/requeteSql.sql param1 param2'
    tout se passe bien.

    Lorsque j'execute la page php en port console avec la même commande que ci-dessus (sans le préfixe sudo)
    comme suit
    > php /monchemin/maPage.php
    cela fonctionne

    Par contre lorsque je demande au serveur, (à apache donc) de faire le boulot il ne se passe rien. Pour faciliter les choses le serveur lors de l'execution de la page php ne m'affiche pas de retour d'erreur

    questions:
    configuration du sudo ?
    pb de droits ?
    pb de PATH ?


    Etant autodidacte je ne pourrai cacher quelques lacunes....
    merci d'avance pour ceux qui voudront bien me donner un début de commencement de petit bout de piste.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Salut,

    As-tu regardé dans l'error_log du serveur apache (normallement /var/log/apache2/error.log si tu utilises la configuration par défaut d'apache)?

  3. #3
    Futur Membre du Club
    Inscrit en
    Juin 2007
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 37
    Points : 9
    Points
    9
    Par défaut
    je vais jeter un oeil...

  4. #4
    Futur Membre du Club
    Inscrit en
    Juin 2007
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 37
    Points : 9
    Points
    9
    Par défaut message dans fichier log apache
    seule indication peu précise (pas certain de pouvoir l'attribuer à l'execution de ma page php) mais qui pourrait me concerner puisqu'il s'agit des bibliothèques sqlplus.

    1
    sqlplus: error while loading shared libraries: libsqlplus.so: cannot open shared object file: No such file or directory

  5. #5
    Invité
    Invité(e)
    Par défaut
    Ok,

    sqlplus ne parvient pas à s'executer car il ne trouve pas la librairie partagé mentionnée.

    La configuration des chemins des librairies partagés s'effectue généralement en définissant la variable d'environnement LD_LIBRARY_PATH. Il faudrait vérifer ce que tu as dans cette variable en mode console

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    echo $LD_LIBRARY_PATH

  6. #6
    Futur Membre du Club
    Inscrit en
    Juin 2007
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 37
    Points : 9
    Points
    9
    Par défaut suite
    la variable $LD_LIBRARY_PATH est bien décrite correctement en tout cas visible en port console.

    Ce qui me fait souci c'est que en port console, loggé avec l'identité de mon serveur apache, "www-data", la requête s’exécute bien preuve en est qu'il trouve bien les librairies et les chemins nécessaires pour trouver sqlplus.

    C'est d'ailleurs parce que je ne pouvais directement invoquer la requête dans la page php que j'envisage de recourir à sudo ????
    Mais je n'ai pas beaucoup plus de succès.

    merci de vos lumières.

  7. #7
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    quel intérêt de passer par une ligne de commende et pas par l'API SQL PHP ?

    A+JYT

  8. #8
    Futur Membre du Club
    Inscrit en
    Juin 2007
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Juin 2007
    Messages : 37
    Points : 9
    Points
    9
    Par défaut trouvé
    solution trouvée:
    En fait pour mettre en oeuvre les variables en question j'utilisais une commande export
    Cette commande se révèle inefficace, il faut lui préférer la commande putenv

    exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    putenv("ORACLE_HOME=/usr/lib/oracle/11.2/client/bin");
    putenv("LD_LIBRARY_PATH=/usr/lib/oracle/11.2/client/lib");
    De ce fait, mon script fonctionne parfaitement et je n'ai même plus besoin de recourir à sudo car mes soucis venaient uniquement de l'environnement nécessaire.

Discussions similaires

  1. Réponses: 3
    Dernier message: 13/05/2009, 22h23
  2. [Système] Exécution commande dans une page PHP
    Par corto31 dans le forum Langage
    Réponses: 7
    Dernier message: 25/11/2008, 15h06
  3. Réponses: 6
    Dernier message: 29/05/2008, 12h22
  4. [Système] executer commande ssh dans une page php
    Par marielaure2805 dans le forum Langage
    Réponses: 2
    Dernier message: 19/10/2006, 10h05
  5. lancer une commande dos dans une page ASP
    Par noznoz78 dans le forum ASP
    Réponses: 4
    Dernier message: 13/02/2006, 19h06

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