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

Langage PHP Discussion :

[Système] Exécution d'une page PHP en ligne de commande


Sujet :

Langage PHP

  1. #1
    Membre confirmé Avatar de dj-julio
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Décembre 2005
    Messages : 745
    Points : 625
    Points
    625
    Par défaut [Système] Exécution d'une page PHP en ligne de commande
    Bonjour,

    Je souhaite exécuter une fichier php qui se trouve sur mon serveur Debian en ligne de commande.

    lorsque je me met dans le répertoire de l'appli php et que je fais la commande :
    /usr/bin/php5 -f bot.php
    ou alors :
    /usr/bin/php5 -f /var/www/bot/bot.php
    Le script se lance correctement en ligne de commande (tout est ok )

    Maintenant si je souhaite lancer cette commande sans me mettre dans le répertoire de l'appli (en vu de pouvoir lancer cette page au boot du poste), je fais :
    /usr/bin/php5 -f /var/www/bot/bot.php
    et ça ne fonctionne pas correctement, il me renvoie les erreurs suivantes :

    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/ldap.so' - /usr/lib/php5/20060613+lfs/ldap.so: cannot open shared object file: No such file or directory in Unknown on line 0
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/snmp.so' - /usr/lib/php5/20060613+lfs/snmp.so: cannot open shared object file: No such file or directory in Unknown on line 0
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/xmlrpc.so' - /usr/lib/php5/20060613+lfs/xmlrpc.so: cannot open shared object file: No such file or directory in Unknown on line 0

    Warning: require_once(./include/bot.conf.php): failed to open stream: No such file or directory in /var/www/bot/bot.php on line 31

    Fatal error: require_once(): Failed opening required './include/bot.conf.php' (include_path='.:/usr/share/php:/usr/share/pear') in /var/www/bot/bot.php on line 31
    Voici le contenu de mon fichier bot.php
    Code php : 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
    50
    51
    52
    53
    <?php 
    /**
     * fichier : bot.php : 
     * Script principal
     *
     * @package Cspbot
     * @since 2006/08/10
     * @version 0.3
     * @author Fabrice Lezoray - Tetsuo - Alain Nicolas (mcAllan)
     * @copyright See licence.txt
     * 
     */
     
    function __autoload($class) {
        $file1 = './classes/class.'.$class.'.php';
        if(is_readable($file1)) {
            include_once $file1;
        }
        $plugin = './plugin/'.$class.'/plug.php';
        if(is_readable($plugin)) {
            include_once $plugin;
        }
    }
     
    if(!isset($argv)) {
        die ('Only batch running');
    }
     
     
     
    require_once('./include/bot.conf.php');
     
    # ---------------------------
    # Instanciation du bot
    # ---------------------------
    $MainProc = new IRCMain($server = IRC_SERVER, $port = IRC_PORT, $chan = '#'.IRC_CHAN, $name = BOT_NICK, MY_IP, MY_DOMAIN);
     
    # ---------------------------
    # Chargement liste des op autorisés
    # ---------------------------
    $MainProc -> setOpList($botOp);
     
    # ---------------------------
    # Chargement des plugins
    # ---------------------------
    $MainProc->loadPlugs();
     
    # ---------------------------
    # Démarrage du bot
    # ---------------------------
    $MainProc->run();
     
    ?>
    P.S : "/usr/bin/php5" <= ceci est le CLI php

    Quelqu'un aurait-il une petite idée pour ce problème ?

    Merci d'avance !!!

  2. #2
    Membre régulier
    Inscrit en
    Janvier 2007
    Messages
    273
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Janvier 2007
    Messages : 273
    Points : 83
    Points
    83
    Par défaut
    Heu pour ta deuxième tentative, tu t'es mis dans quel répertoire au juste?

  3. #3
    Membre confirmé Avatar de dj-julio
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Décembre 2005
    Messages : 745
    Points : 625
    Points
    625
    Par défaut
    Oups pour la Deuxième tentative, je me suis mis à la racine du serveur, là où on arrive après s'être logué en root.

    Petite mise à jour ....
    à la racine du serveur, je fais ce qui est en gras et j'obtiens les erreur ci-dessous.
    debian:/# /usr/bin/php5 -f /var/www/bot/bot.php
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/ldap.so' - /usr/lib/php5/20060613+lfs/ldap.so: cannot open shared object file: No such file or directory in Unknown on line 0
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/snmp.so' - /usr/lib/php5/20060613+lfs/snmp.so: cannot open shared object file: No such file or directory in Unknown on line 0
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/xmlrpc.so' - /usr/lib/php5/20060613+lfs/xmlrpc.so: cannot open shared object file: No such file or directory in Unknown on line 0

    Warning: require_once(./include/bot.conf.php): failed to open stream: No such file or directory in /var/www/bot/bot.php on line 31

    Fatal error: require_once(): Failed opening required './include/bot.conf.php' (include_path='.:/usr/share/php:/usr/share/pear') in /var/www/bot/bot.php on line 31
    debian:/#
    dans le dossier de l'appli (/var/www/bot/) je fais ce qui est en gras et j'obtiens ce qu'il y a en dessous ; puis tout marche correctement.
    debian:/var/www/bot# /usr/bin/php5 -f bot.php
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/ldap.so' - /usr/lib/php5/20060613+lfs/ldap.so: cannot open shared object file: No such file or directory in Unknown on line 0
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/snmp.so' - /usr/lib/php5/20060613+lfs/snmp.so: cannot open shared object file: No such file or directory in Unknown on line 0
    PHP Warning: PHP Startup: Unable to load dynamic library '/usr/lib/php5/20060613+lfs/xmlrpc.so' - /usr/lib/php5/20060613+lfs/xmlrpc.so: cannot open shared object file: No such file or directory in Unknown on line 0

    En fait j'ai des erreurs dans les 2 cas, mais dans le deuxième cas, ça n'est pas bloquant.

    Quelqu'un saurait-il comment éviter ces 2 erreurs dans le 1er cas ?

    Merci.

  4. #4
    Rédacteur
    Avatar de _Mac_
    Profil pro
    Inscrit en
    Août 2005
    Messages
    9 601
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 9 601
    Points : 12 977
    Points
    12 977
    Par défaut
    Pour la première série d'erreurs (cannot open shared object file), je dirais que c'est parce que tu as des librairies/extensions activées dans php.ini sans avoir les .so qui vont avec. Ce sont les extensions ldap, snmp et xmlrpc. Commente les lignes correspondantes dans le fichier php.ini pour voir.

    Pour la seconde série d'erreurs, c'est un pb de calcul de chemins relatifs. En mode commande, PHP prend visiblement comme chemin de référence le contenu de la variable include_path définie dans php.ini ainsi que le répertoire à partir duquel la commande php a été appelée et pas le chemin du script. En mode Web, c'est le serveur Web qui fait un "cd" comme il faut avant d'exécuter PHP. Du coup, tu as plusieurs solutions :
    • modifier la variable include_path
    • faire un cd ... avant d'appeler la commande php
    • faire un cd (chdir) explicite en haut de chaque script appelé pour redéfinir le chemin d'exécution du script

    Y en a peut-être d'autres (du style une option de la commande php) mais je ne les vois pas (faut dire que je suis myope, aussi).

  5. #5
    Membre confirmé Avatar de dj-julio
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Décembre 2005
    Messages : 745
    Points : 625
    Points
    625
    Par défaut
    Merci beaucoup _Mac_ ,

    Pour les extensions qui buggaient, c'est réparé !! merci
    En ce qui concerne le paramètre "include_path" du coup, je ne sais pas trop quoi mettre ?
    Je souhaite exécuter la page php en étant à la racine du serveur (connecté en root).

    Merci encore

  6. #6
    Rédacteur
    Avatar de _Mac_
    Profil pro
    Inscrit en
    Août 2005
    Messages
    9 601
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 9 601
    Points : 12 977
    Points
    12 977
    Par défaut
    Pourquoi il faut que tu exécutes le script depuis la racine ? Pourquoi ne pas faire un petit script shell qui fait ceci :
    Code shell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    #!/bin/ksh
     
    cd /var/www/bot
    /usr/bin/php5 -f bot.php
    ?

  7. #7
    Membre confirmé Avatar de dj-julio
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France, Finistère (Bretagne)

    Informations forums :
    Inscription : Décembre 2005
    Messages : 745
    Points : 625
    Points
    625
    Par défaut
    lol parce que je n'y connais rien du tout en linux, je n'y suis que depuis 2semaines ^^

    Merci de ta réponse Mc Gyver
    Je vais tester cela.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 26/05/2010, 11h13
  2. Réponses: 8
    Dernier message: 27/09/2008, 12h54
  3. Réponses: 10
    Dernier message: 15/07/2008, 11h52
  4. Réponses: 3
    Dernier message: 14/12/2006, 11h46
  5. [Système] Parsing d'une page PHP
    Par Royd938 dans le forum Langage
    Réponses: 2
    Dernier message: 08/05/2006, 12h21

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