2011-08-07 1 views
2

Zend_Log(Zend_Log_Writer_Streamを含む)のインスタンスをZend_Cache(推奨)またはZend_Registry(フォールバック)に保存しようとしていますが、代わりにカスタムヘルパーを抽象レイヤー直接アクセスの。カスタムヘルパーの有無にかかわらずZend_Cache/Zend_Registryにインスタンスを保存する

直接除き、Zend_Registryを使用している場合を除き問題

  • 、毎回Zend_Log_Writer_Streamの_streamプロパティが消えます。

私は自分のコードを生成した出力とともに添付しました。

theselinks私は他の作家Zend_Log_Writer_Databaseがアプリケーションよりも別のデータベースに書き込むため、私はそれを初期化する必要があるため、私は従っていません。今のところ私はそれをコメントアウトしています。

ロガー、ローカル変数

: -

bootstrap.phpの

class Helper_SCacheOrRegistry { 

    private $_source; 
    private static $_instance; 
    private $_functionsArray = array('Cache' => array(
      'get' => '_getFromCache', 
      'set' => '_saveInCache', 
      'del' => '_deleteFromCache', 
      'exists' => '_existsInCache'), 
     'Registry' => array(
      'get' => '_getFromRegistry', 
      'set' => '_saveInRegistry', 
      'del' => '_deleteFromRegistry', 
      'exists' => '_existsInRegistry', 
     ) 
    ); 

    public static function getInstance() { 
     if (!isset(self::$_instance)) { 
      $c = __CLASS__; 
      self::$_instance = new $c(); 
     } 

     return self::$_instance; 
    } 


    private function _getSource($forceRegistry = null) { 
     if(true === $forceRegistry) 
      return Zend_Registry::getInstance(); 

     if (Zend_Registry::getInstance()->offsetExists('apcCache')) 
      return Zend_Registry::get('apcCache'); 
     else 
      return Zend_Registry::getInstance(); 

    } 

    private function _isSourceCache() { 
     return (!$this->_source instanceof Zend_Registry); 
    } 

    public function createCacheId($id) { 
     return md5(',[email protected]!u$#~\|3Pa^e1%oh&s0*<h(7)o-+h/t.' . $id); 
    } 

    public function set($key, $value, $forceRegistry = null) { 
     $this->_fire('set', $this->createCacheId($key), $value, $forceRegistry); 
    } 

    public function get($key, $forceRegistry = null) { 
     return $this->_fire('get', $this->createCacheId($key), null, $forceRegistry); 
    } 

    public function del($key, $forceRegistry = null) { 
     return $this->_fire('del', $this->createCacheId($key), null, $forceRegistry); 
    } 

    public function exists($key, $forceRegistry = null) { 
     return $this->_fire('exists', $this->createCacheId($key), null, $forceRegistry); 
    } 

    private function _fire($method, $key, $value = null, $forceRegistry = null) { 


     $this->_source = $this->_getSource($forceRegistry); 
     $call = ($this->_isSourceCache()) ? 
       $this->_functionsArray['Cache'][$method] : $this->_functionsArray['Registry'][$method]; 

     return (isset($value)) ? $this->$call($key, $value) : $this->$call($key); 
    } 

    private function _getFromCache($key) { 
     return $this->_existsInCache($key); 
    } 

    private function _saveInCache($key, $value) { 
     if ($this->_existsInCache($key)) 
      return false; 

     $this->_source->save($value, $key); 
     return true; 
    } 

    private function _deleteFromCache($key) { 
     if (!$this->_existsInCache($key)) 
      return false; 

     $this->_source->remove($key); 
     return true; 
    } 

    private function _existsInCache($key) { 
     return $this->_source->load($key); 
    } 

    private function _getFromRegistry($key) { 
     if ($this->_existsInRegistry($key)) 
      return unserialize($this->_source->get($key)); 

     return false; 
    } 

    private function _saveInRegistry($key, $value) { 
     if ($this->_existsInRegistry($key)) 
      return false; 

     $this->_source->set($key, serialize($value)); 
     return true; 
    } 

    private function _deleteFromRegistry($key) { 
     if (!$this->_existsInCache($key)) 
      return false; 

     $this->_source->offsetUnset($key); 
     return true; 
    } 

    private function _existsInRegistry($key) { 
     return $this->_source->isRegistered($key); 
    } 

} 

出力Helper_SCacheOrRegistry.php

protected function _initLog() { 
     // instantiate CacheOrRegistry variable. 
     $this->_cor = Helper_SCacheOrRegistry::getInstance(); 

     // make sure its not already cached and config for this resource exists. 
     if ($this->_cor->exists('logger') || !($config = $this->_config->resources->log)) 
      return; 


     $logger = new Zend_Log(); 
     $config = $config->toArray(); 

     /* 

    if (isset($config['db']) && is_array($config['db'])) { 
     $dbParams = $config['db']; 
     $writerDb = new Zend_Log_Writer_Db(
         $this->_cor->get('logDb'), 
         $dbParams['writerParams']['table'], 
         $dbParams['writerParams']['columnMapping']); 

     if (isset($dbParams['filterName'])) { 

      switch ($dbParams['filterName']) { 
       case 'Priority': 
        $writerDb->addFilter(new Zend_Log_Filter_Priority($dbParams['filterParams']['priority'])); 
        break; 
      } 
     } 

     $logger->addWriter($writerDb); 
    } 
    */ 

     if('development' === APPLICATION_ENV) { 
     $fileParams = $this->_options['resources']['log']['file']; 
     if(!isset($fileParams) || !(is_array($fileParams))) 
      return; 

     $writerFile = new Zend_Log_Writer_Stream($fileParams['writerParams']['path'],$fileParams['writerParams']['mode']); 
     $writerFile->setFormatter(new Zend_Log_Formatter_Simple($fileParams['writerParams']['format'])); 

     if (isset($fileParams['filterName'])) { 
      switch ($fileParams['filterName']) { 
       case 'Priority': 
        $writerFile->addFilter(new Zend_Log_Filter_Priority($fileParams['filterParams']['priority'])); 
        break; 
      } 
     } 

     $logger->addWriter($writerFile); 
     } 



     $logger->setEventItem('user_agent', $_SERVER['HTTP_USER_AGENT']); 
     $logger->setEventItem('get_vars', serialize($_GET)); 
     $logger->setEventItem('post_vars', serialize($_POST)); 
     $logger->setEventItem('ip', $_SERVER['REMOTE_ADDR']); 
     $logger->setEventItem('username', $this->_username); 



     // This has issue of missing _stream, Using Custom Helper with Registry use force. 
     $this->_cor->set('logger', $logger, true); 
     $loggerRC = $this->_cor->get('logger', true); 

     // This also has issue of missing _stream, Using Custom Helper with apc Cache 
     $this->_cor->set('logger', $logger); 
     $loggerCC = $this->_cor->get('logger'); 

     // This works perfectly. 
     Zend_Registry::set($this->_cor->createCacheId('loggerR'), $logger); 
     $loggerZ = Zend_Registry::get($this->_cor->createCacheId('loggerR')); 

     // This also seems to have issue of missing _stream, Using apc Cache directly 
     $cache = Zend_Registry::get('apcCache'); 
     $cache->save($logger, $this->_cor->createCacheId('loggerC')); 
     $loggerC = $cache->load($this->_cor->createCacheId('loggerC')); 


     echo "<h3>Logger, local variable</h3>"; 
     var_dump($logger); 

     echo "<h3>Logger, from Registry using custom helper</h3>"; 
     var_dump($loggerRC); 

     echo "<h3>Logger, from apc cache using custom helper</h3>"; 
     var_dump($loggerCC); 

     echo "<h3>Logger, from Zend_Registry, direct.</h3>"; 
     var_dump($loggerZ); 

     echo "<h3>Logger, from apc Cache, Direct.</h3>"; 
     var_dump($loggerC); 
     exit; 
    } 

をクリッピング10

object(Zend_Log)[84] protected '_priorities' => array 0 => string 'EMERG' (length=5) 1 => string 'ALERT' (length=5) 2 => string 'CRIT' (length=4) 3 => string 'ERR' (length=3) 4 => string 'WARN' (length=4) 5 => string 'NOTICE' (length=6) 6 => string 'INFO' (length=4) 7 => string 'DEBUG' (length=5) protected '_writers' => array 0 => object(Zend_Log_Writer_Stream)[93] protected '_stream' => resource(77, stream) protected '_filters' => array 0 => object(Zend_Log_Filter_Priority)[94] protected '_priority' => int 7 protected '_operator' => string '<=' (length=2) protected '_formatter' => object(Zend_Log_Formatter_Simple)[95] protected '_format' => string ' [ %ip% ] - [ %timestamp% ] [ %user_agent% ] - [ %username% ] [ %priorityName% : %message% ] [ POST: %post_vars% ] [ GET: %get_vars% ] ' (length=161) protected '_filters' => array empty protected '_extras' => array 'user_agent' => string 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.18 Safari/535.1' (length=99) 'get_vars' => string 'a:0:{}' (length=6) 'post_vars' => string 'a:0:{}' (length=6) 'ip' => string '127.0.0.1' (length=9) 'username' => string 'guest' (length=5) protected '_defaultWriterNamespace' => string 'Zend_Log_Writer' (length=15) protected '_defaultFilterNamespace' => string 'Zend_Log_Filter' (length=15) protected '_defaultFormatterNamespace' => string 'Zend_Log_Formatter' (length=18) protected '_origErrorHandler' => null protected '_registeredErrorHandler' => boolean false protected '_errorHandlerMap' => boolean false protected '_timestampFormat' => string 'c' (length=1) 

レジストリは、直接なZend_Registryから、カスタムヘルパー

object(Zend_Log)[100] 
    protected '_priorities' => 
    array 
     0 => string 'EMERG' (length=5) 
     1 => string 'ALERT' (length=5) 
     2 => string 'CRIT' (length=4) 
     3 => string 'ERR' (length=3) 
     4 => string 'WARN' (length=4) 
     5 => string 'NOTICE' (length=6) 
     6 => string 'INFO' (length=4) 
     7 => string 'DEBUG' (length=5) 
    protected '_writers' => 
    array 
     0 => 
     object(Zend_Log_Writer_Stream)[101] 
      protected '_stream' => int 0 
      protected '_filters' => 
      array 
       0 => 
       object(Zend_Log_Filter_Priority)[102] 
        protected '_priority' => int 7 
        protected '_operator' => string '<=' (length=2) 
      protected '_formatter' => 
      object(Zend_Log_Formatter_Simple)[103] 
       protected '_format' => string ' [ %ip% ] - [ %timestamp% ] [ %user_agent% ] - [ %username% ] 
     [ %priorityName% : %message% ] 
     [ POST: %post_vars% ] 
     [ GET: %get_vars% ] 
' (length=161) 
    protected '_filters' => 
    array 
     empty 
    protected '_extras' => 
    array 
     'user_agent' => string 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.18 Safari/535.1' (length=99) 
     'get_vars' => string 'a:0:{}' (length=6) 
     'post_vars' => string 'a:0:{}' (length=6) 
     'ip' => string '127.0.0.1' (length=9) 
     'username' => string 'guest' (length=5) 
    protected '_defaultWriterNamespace' => string 'Zend_Log_Writer' (length=15) 
    protected '_defaultFilterNamespace' => string 'Zend_Log_Filter' (length=15) 
    protected '_defaultFormatterNamespace' => string 'Zend_Log_Formatter' (length=18) 
    protected '_origErrorHandler' => null 
    protected '_registeredErrorHandler' => boolean false 
    protected '_errorHandlerMap' => boolean false 
    protected '_timestampFormat' => string 'c' (length=1) 

ロガーを使用してAPCキャッシュから、カスタムヘルパー

object(Zend_Log)[96] 
    protected '_priorities' => 
    array 
     0 => string 'EMERG' (length=5) 
     1 => string 'ALERT' (length=5) 
     2 => string 'CRIT' (length=4) 
     3 => string 'ERR' (length=3) 
     4 => string 'WARN' (length=4) 
     5 => string 'NOTICE' (length=6) 
     6 => string 'INFO' (length=4) 
     7 => string 'DEBUG' (length=5) 
    protected '_writers' => 
    array 
     0 => 
     object(Zend_Log_Writer_Stream)[97] 
      protected '_stream' => int 0 
      protected '_filters' => 
      array 
       0 => 
       object(Zend_Log_Filter_Priority)[98] 
        protected '_priority' => int 7 
        protected '_operator' => string '<=' (length=2) 
      protected '_formatter' => 
      object(Zend_Log_Formatter_Simple)[99] 
       protected '_format' => string ' [ %ip% ] - [ %timestamp% ] [ %user_agent% ] - [ %username% ] 
     [ %priorityName% : %message% ] 
     [ POST: %post_vars% ] 
     [ GET: %get_vars% ] 
' (length=161) 
    protected '_filters' => 
    array 
     empty 
    protected '_extras' => 
    array 
     'user_agent' => string 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.18 Safari/535.1' (length=99) 
     'get_vars' => string 'a:0:{}' (length=6) 
     'post_vars' => string 'a:0:{}' (length=6) 
     'ip' => string '127.0.0.1' (length=9) 
     'username' => string 'guest' (length=5) 
    protected '_defaultWriterNamespace' => string 'Zend_Log_Writer' (length=15) 
    protected '_defaultFilterNamespace' => string 'Zend_Log_Filter' (length=15) 
    protected '_defaultFormatterNamespace' => string 'Zend_Log_Formatter' (length=18) 
    protected '_origErrorHandler' => null 
    protected '_registeredErrorHandler' => boolean false 
    protected '_errorHandlerMap' => boolean false 
    protected '_timestampFormat' => string 'c' (length=1) 

ロガーを使用してから、ロガー、。 APCキャッシュ、直接から

object(Zend_Log)[84] 
    protected '_priorities' => 
    array 
     0 => string 'EMERG' (length=5) 
     1 => string 'ALERT' (length=5) 
     2 => string 'CRIT' (length=4) 
     3 => string 'ERR' (length=3) 
     4 => string 'WARN' (length=4) 
     5 => string 'NOTICE' (length=6) 
     6 => string 'INFO' (length=4) 
     7 => string 'DEBUG' (length=5) 
    protected '_writers' => 
    array 
     0 => 
     object(Zend_Log_Writer_Stream)[93] 
      protected '_stream' => resource(77, stream) 
      protected '_filters' => 
      array 
       0 => 
       object(Zend_Log_Filter_Priority)[94] 
        protected '_priority' => int 7 
        protected '_operator' => string '<=' (length=2) 
      protected '_formatter' => 
      object(Zend_Log_Formatter_Simple)[95] 
       protected '_format' => string ' [ %ip% ] - [ %timestamp% ] [ %user_agent% ] - [ %username% ] 
     [ %priorityName% : %message% ] 
     [ POST: %post_vars% ] 
     [ GET: %get_vars% ] 
' (length=161) 
    protected '_filters' => 
    array 
     empty 
    protected '_extras' => 
    array 
     'user_agent' => string 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.18 Safari/535.1' (length=99) 
     'get_vars' => string 'a:0:{}' (length=6) 
     'post_vars' => string 'a:0:{}' (length=6) 
     'ip' => string '127.0.0.1' (length=9) 
     'username' => string 'guest' (length=5) 
    protected '_defaultWriterNamespace' => string 'Zend_Log_Writer' (length=15) 
    protected '_defaultFilterNamespace' => string 'Zend_Log_Filter' (length=15) 
    protected '_defaultFormatterNamespace' => string 'Zend_Log_Formatter' (length=18) 
    protected '_origErrorHandler' => null 
    protected '_registeredErrorHandler' => boolean false 
    protected '_errorHandlerMap' => boolean false 
    protected '_timestampFormat' => string 'c' (length=1) 

ロガー、。

object(Zend_Log)[104] 
    protected '_priorities' => 
    array 
     0 => string 'EMERG' (length=5) 
     1 => string 'ALERT' (length=5) 
     2 => string 'CRIT' (length=4) 
     3 => string 'ERR' (length=3) 
     4 => string 'WARN' (length=4) 
     5 => string 'NOTICE' (length=6) 
     6 => string 'INFO' (length=4) 
     7 => string 'DEBUG' (length=5) 
    protected '_writers' => 
    array 
     0 => 
     object(Zend_Log_Writer_Stream)[105] 
      protected '_stream' => int 0 
      protected '_filters' => 
      array 
       0 => 
       object(Zend_Log_Filter_Priority)[106] 
        protected '_priority' => int 7 
        protected '_operator' => string '<=' (length=2) 
      protected '_formatter' => 
      object(Zend_Log_Formatter_Simple)[107] 
       protected '_format' => string ' [ %ip% ] - [ %timestamp% ] [ %user_agent% ] - [ %username% ] 
     [ %priorityName% : %message% ] 
     [ POST: %post_vars% ] 
     [ GET: %get_vars% ] 
' (length=161) 
    protected '_filters' => 
    array 
     empty 
    protected '_extras' => 
    array 
     'user_agent' => string 'Mozilla/5.0 (X11; Linux i686) AppleWebKit/535.1 (KHTML, like Gecko) Chrome/14.0.835.18 Safari/535.1' (length=99) 
     'get_vars' => string 'a:0:{}' (length=6) 
     'post_vars' => string 'a:0:{}' (length=6) 
     'ip' => string '127.0.0.1' (length=9) 
     'username' => string 'guest' (length=5) 
    protected '_defaultWriterNamespace' => string 'Zend_Log_Writer' (length=15) 
    protected '_defaultFilterNamespace' => string 'Zend_Log_Filter' (length=15) 
    protected '_defaultFormatterNamespace' => string 'Zend_Log_Formatter' (length=18) 
    protected '_origErrorHandler' => null 
    protected '_registeredErrorHandler' => boolean false 
    protected '_errorHandlerMap' => boolean false 
    protected '_timestampFormat' => string 'c' (length=1) 

答えて

2
  • 格納されている場合はZend_Logはシリアル化されるべきではありません。
  • Zend_Cacheは、文字列のみを格納するオブジェクトを直列化する必要があるため、オプションではありません。
  • Zend_Registryは、コードのためにいくつかのシリアライゼーションが行われていたため、ヘルパークラスを使用していませんでした。それを削除すると問題が解決しました。

だから、要するに:

  • 使用なZend_RegistryなZend_Registry
に格納する際に、オブジェクト
  • をシリアライズしない保存します
  • 関連する問題