Zend_Log in application.ini

后端 未结 4 1392
日久生厌
日久生厌 2021-01-01 02:31

is there any example how to setup an instance of zend log from application.ini? I have only found an example for logging to an file, but i want to log into an SQLITE databas

相关标签:
4条回答
  • 2021-01-01 02:31

    Good question. I can't find a way to instantiate the Zend_Log_Writer_Db from a bootstrap config. The writer class requires a Zend_Db_Adapter object. It doesn't accept a string.

    The ZF project needs to develop this use case further. They don't even have any unit tests for Zend_Application_Resource_Log that include a Db writer.

    The best I can suggest until then is that you Bootstrap class needs to customize the Log resource in an _initLog() method.

    class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
    {
    
      protected function _initDb()
      {
        if ($this->hasPluginResource("db")) {
          $r = $this->getPluginResource("db");
          $db = $r->getDbAdapter();
          Zend_Registry::set("db", $db);
        }
      }
    
      protected function _initLog()
      {
        if ($this->hasPluginResource("log")) {
          $r = $this->getPluginResource("log");
          $log = $r->getLog();
    
          $db = Zend_Registry::get("db");
          $writer = new Zend_Log_Writer($db, "log", ...columnMap...);
          $log->addWriter($writer);
    
          Zend_Registry::set("log", $log);
        }
      }
    
    }
    
    0 讨论(0)
  • 2021-01-01 02:35

    Since ZF 1.10alpha (at least), the following has been true.

    // e.g. 1 - works
    resources.log.firebug.writerName = "Firebug"
    // e.g. 2 - fails
    resources.log.writerName = "Firebug"
    

    NOTE: the arbitrary array key 'firebug'. When the Zend_Log factory churns over the resource's log config, example 1 will be passed as an array to Zend_Log->addWriter() (triggering the _constructWriterFromConfig() method), whilst example 2 will simply pass a string (triggering an exception).

    (I know this is old, and I'm using a Firebug logger example, but the same applies to all log writers)

    0 讨论(0)
  • 2021-01-01 02:49

    This should work - I will test fully later (not at my dev machine now)

    Zend_Application_Resource_Log can setup an instance of a Zend_Log from application.ini

    resources.log.writerName = "db"
    resources.log.writerParams.db.adapter = "PDO_SQLITE"
    resources.log.writerParams.db.dbname = APPLICATION_PATH "/../db/logdb.sqlite"
    resources.log.writerParams.db.table = "log"  
    
    0 讨论(0)
  • 2021-01-01 02:54

    Here in the manual: you can find an example how to write your log file into the database.Is that what you mean?

    0 讨论(0)
提交回复
热议问题