Pregunta

Me puso mis madereros en mi Bootstrap.php este modo:

 $logger = new Zend_Log();
    if($environment->debug == '1')
    {
        $stream = @fopen('/var/www/html/rta/rta.log','a',false);
        if(!$stream){ throw new Exception('Failed to open log stream'); }
        $writer = new Zend_Log_Writer_Stream($stream);
        $logger->addWriter($writer);
        $logger->addWriter(new Zend_Log_Writer_Firebug());
    }
    else
    {
        // Do something else
    }
    Zend_Registry::set('logger',$logger);

Tengo el siguiente código que he creado a fallar:

$data = array(
            'config_id'      => $config->getConfigId(),
            'pass_column'    => $config->getPassColumn(),
            'filename'       => $config->getFilename(),
            'date_format'    => $config->getDateFormat(),
            'mapping_config' => $config->getMappingConfig(),
            'config_name'    => $config->getConfigName(),
            'client_id'      => $config->getClientId(),
            'description'    => $config->getDescription(),
        );

        $where = $this->getDbTable()->getAdapter()->quoteInto('config_id = ?',$config->getConfigId());
        $where = null;
        try
        {
            $this->getDbTable()->update($data,$where);
        }catch(Exception $e)
        {
            Zend_Registry::get('logger')->err('Could not update configuration.');
            Zend_Registry::get('logger')->err($e);
            return false;
        }
        return true;

Me puso dos escritores de registro: Secuencia y FirePHP. El escritor registro de flujo atrapado con éxito y escribió la excepción sino FirePHP no hizo nada. Si pongo otros mensajes de registro de otros lugares en mi código, como indexAction que muestra los muy bien en ambos. Me estoy perdiendo algo?

Editar El código de error está en mi asignador de bases de datos, no un controlador. Podría ser que no tiene acceso a la encabezados HTTP?

¿Fue útil?

Solución

El siguiente ejemplo siguiente muestra cómo hacer FirePHP obtener la información de la cabecera que necesita sin necesidad de utilizar el FrontController.     

    // create the logger and log writer
    $writer = new Zend_Log_Writer_Firebug();
    $logger = new Zend_Log($writer);

    // get the wildfire channel
    $channel = Zend_Wildfire_Channel_HttpHeaders::getInstance();

    // create and set the HTTP response
    $response = new Zend_Controller_Response_Http();
    $channel->setResponse($response);

    // create and set the HTTP request
    $channel->setRequest(new Zend_Controller_Request_Http());

    // record log messages
    $logger->info('info message');
    $logger->warn('warning message');
    $logger->err('error message');

    // insert the wildfire headers into the HTTP response
    $channel->flush();

    // send the HTTP response headers
    $response->sendHeaders();
?>
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top