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

Zend Framework PHP Discussion :

Zend_Log problème avec la gestion des erreurs [ZF 1.7]


Sujet :

Zend Framework PHP

  1. #1
    Membre actif Avatar de miya
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 469
    Points : 240
    Points
    240
    Par défaut Zend_Log problème avec la gestion des erreurs
    Bonsoir,

    Après deux heures a me tapé la tete sur le livre de Pauli, je décide de venir faire un tour ici, pour éventuel de l'aide.

    1/
    J'essaye de mettre en place la gestion des erreurs, et rien ne marche.. C'est surement que je ne dois pas assimilé tous les aspects, déjà
    bootstrap.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    	$log = new Zend_log();
    	$writer = new Zend_Log_Writer_Stream($config->logfile);
    	$log->addWriter($writer);
    fichier ini
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    [prod : general]
    logfile = /log/test.txt
    debug = 0
    J'ai l'erreur suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Fatal error: Uncaught exception 'Zend_Log_Exception' with message '"/log/test.txt" cannot be opened with mode "a"' in C:\wamp\www\webspace\library\Zend\Log\Writer\Stream.php:66 Stack trace: #0 C:\wamp\www\webspace\public\index.php(31): Zend_Log_Writer_Stream->__construct('/log/test.txt') #1 {main} thrown in C:\wamp\www\webspace\library\Zend\Log\Writer\Stream.php on line 66
    J'ai créé mon dossier log dans le dossier public de mon site ?

    2/
    Pour continuer tout meme a développer, j'affiche les erreurs a l'écran en initialisation le logfile a php://output. Je souhaite développé un controler errorControler et implémenter la méthode errorAction, comme vu à la page 93 du livre de pauli :

    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
    23
    24
    25
    26
     
    $errors = $this->_getParam('error_handler');
     
    	   if($error->exception instanceof Zend_Controller_Exception){
    			$log = "notice";
    			$this->getResponse()->setHttpResponseCode(404);
    			$this->view->message = $this->view->translate("La page que vous demandé n'a pas pu être trouvée");
    			} elseif($error->exception instanceof Zend_Db_Exception){
    				$log = "emerg";
    				$this->getResponse()->setHttpResponseCode(503);
    				$this->view->message = $this->view->translate("Un problème de base de données nous empêche de servir votre requête");
    				}elseif($error->exception instanceof webspace_UserException){
    					$log = "user";
    					$this->view->message = $this->view->translate($error->exception->getMessage());
    					}else{
    						$this->getResponse()->setHttpResponseCode(503);
    						$log = "alert";
    						$this->view->message = $this->view->translate("Notre site est momentanément indisponible");
    					}
    		$this->_response->clearBody();
     
    		if($this->getInvokeArg('debug') == 1){
    			$this->view->message = $errors->exception;
    		}
     
    		Zend_Registry::get('log')->$log($errors->exception);
    Mais la aussi je ne comprend tjs rien, car si je comprend bien que je met une action bidon dans mon url, je dois bien rentrer dans le 1er if, et me personnaliser l'erreur, mais il m'indique tjs pas défaut l'erreur de zend :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Invalid controller specified (fds)

  2. #2
    Membre actif Avatar de miya
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 469
    Points : 240
    Points
    240
    Par défaut
    Je ne suis peut être pas clair dans mes propos, n'hésiter pas à me le dire si c'est le cas

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    47
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 47
    Points : 54
    Points
    54
    Par défaut
    Pour la première erreur déjà, il faut que ton fichier /log/test.txt soit accessible en ecriture pour l'utilisateur qui éxécute apache.

  4. #4
    Membre actif Avatar de miya
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 469
    Points : 240
    Points
    240
    Par défaut
    On est d'accord, mais j'ai essayé d'une autre manière, et si je créé un fichier qui regroupe l'import de mon fichier ini et la configuration de mon log, comme ceci:

    test_log.php
    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
     
    <?php
    	define('APP_MODE', 'dev');
     
    	include 'Zend/Loader.php';
    	Zend_Loader::registerAutoload();
     
    	$appPath = dirname(__FILE__);
    	$configIni = new Zend_Config_Ini($appPath . '\zend_config_ini.ini',APP_MODE);
     
    	$log = new Zend_log();
    	$writer = new Zend_Log_Writer_Stream($configIni->logfile);
    	$log->addWriter($writer);
     
    	try{
    		$log->method();
    	}catch(Exception $ex){
    		$log->log( $ex, Zend_Log::INFO);
    	}
    J'ai aucun probleme, le fichier test est créé dans un répertoire log situé dans le meme répertoire que le fichier php

    Et quand j'essai, pour mettre le code de l'import du fichier 'ini' et la gestion de log dans le fichier bootstrap, et à partir de mon indexController généré une erreur, j'ai toujours le problème cité en 1/

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    47
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 47
    Points : 54
    Points
    54
    Par défaut
    Je ne comprends pas bien ce qu'il se passe, mais en tout cas, le chemin que tu spécifies dans ton fichier INI est un chemin relatif au système de fichiers, et pas relatif à ton serveur WEB. Tu devrais plutôt mettre C:\Temp\log.txt d'après moi ... ?

  6. #6
    Membre actif Avatar de miya
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 469
    Points : 240
    Points
    240
    Par défaut
    Citation Envoyé par Seb147 Voir le message
    Je ne comprends pas bien ce qu'il se passe, mais en tout cas, le chemin que tu spécifies dans ton fichier INI est un chemin relatif au système de fichiers, et pas relatif à ton serveur WEB. Tu devrais plutôt mettre C:\Temp\log.txt d'après moi ... ?
    es tu sur ? Je pense que le chemin dépend du serv web. Test le code ci dessus, et tu devrais avoir le fichier créer dans le meme dossier ou est situé ton fichier php.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    47
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 47
    Points : 54
    Points
    54
    Par défaut
    J'ai regardé la doc de Zend_Log et il est marqué que :
    Pour écrire des données dans un fichier, employer un des Filesystem URLs:
    Donc les 2 méthodes fonctionnent

    Par contre, la doc de PHP dit que :
    Filesystem est le gestionnaire par défaut de PHP et il représente les fichiers locaux. Lorsqu'un chemin relatif est spécifié (un chemin qui ne commence pas par /, \, \\, ou une lettre de lecteur Windows), le chemin sera calculé relativement à la position courante. Dans de nombreux cas, c'est le dossier de résidence du script, à moins qu'il n'ait été modifié. En utilisant la version CLI, le chemin sera calculé par rapport au dossier d'appel du script.
    Or, tu mets /log/test.txt comme chemin, donc il doit prendre ça pour un chemin absolu du coup, non ?

  8. #8
    Membre actif Avatar de miya
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 469
    Points : 240
    Points
    240
    Par défaut
    Après des tests, je pense que le chemin est relatif. Il créé un fichier dans le dossier qui a créé l'objet log.

    Si des spécialistes pouvaient nous éclaircir ? Merci d'avance de votre aide

  9. #9
    Membre expert
    Avatar de Eusebe
    Inscrit en
    Mars 2006
    Messages
    1 992
    Détails du profil
    Informations personnelles :
    Âge : 46

    Informations forums :
    Inscription : Mars 2006
    Messages : 1 992
    Points : 3 344
    Points
    3 344
    Par défaut
    Bonjour,

    Zend_Log_Writer_Stream utilise en interne fopen pour ouvrir le flux et fwrite pour y écrire (n'hésitez pas à consulter les classes du framework pour mieux comprendre son fonctionnement interne...).

    Donc le paramètre attendu par cette classe est le même que celui de fopen. Ca peut être soit un chemin relatif (par rapport au fichier courant), soit un chemin absolu, soit une URL (encore faut-il pouvoir l'ourir en écriture...).

    Dans ton cas '/log/test.txt' est bien un chemin absolu comme indiqué par Seb147. Mais c'est un chemin absolu sous une forme 'Unix / Linux'... Sauf erreur, ça essaiera de créer le fichier test.txt dans le répertoire 'X:\log', X étant le lecteur contenant ton script.

  10. #10
    Membre actif Avatar de miya
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    469
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 469
    Points : 240
    Points
    240
    Par défaut
    Ok merci

    Voila comment il fallait procéder :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $dir = dirname(__FILE__);
    $writer = new Zend_Log_Writer_Stream($dir.$config->logfile);

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

Discussions similaires

  1. Problème avec la gestion des événements
    Par Franck.H dans le forum SDL
    Réponses: 32
    Dernier message: 26/02/2007, 16h01
  2. Problème sur la gestion des erreurs
    Par ronio dans le forum Langage
    Réponses: 4
    Dernier message: 08/11/2006, 09h47
  3. [debutant]J'ai du mal avec la gestion des erreurs
    Par gillou13 dans le forum Langage
    Réponses: 5
    Dernier message: 02/06/2006, 14h33
  4. Problème avec la "Gestion des bibliothèques dynamiques"
    Par GoustiFruit dans le forum Delphi
    Réponses: 15
    Dernier message: 31/05/2006, 09h54
  5. Problème avec la gestion des événements
    Par CynO dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 17/10/2005, 10h07

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