PHP:$这不是一个对象

时间:2011-06-21 09:40:14

标签: apache centos this php-5.3


我在我们的一个网站上遇到了这个非常奇怪的错误。该网站已经正常工作了大约一年,但是昨天突然它开始抛出“ramdom”500错误,statig例如$这不是一个对象,或者包含随机失败(任何一个都没有失败)情况)。

代码示例:

     //class Enviroment    
     219 public function run()
     220 {
     221  //vložit prostředí
     222  if (class_exists('CONFIG')) {
     223   $this->dir_basic = Config::$DirBasic;
     224  }
     225  include_once($this->dir_basic . 'web/libsf/enviroment/types/' . ($this->mode == 'dev' ? 'dev' : 'prod') . '.php');
     226
     227  //vytvořit třídu prostředí
     228  $enviroment_class = 'Enviroment' . $this->mode;
     229  $this->enviroment = new $enviroment_class($this);
     230  $this->enviroment->pre_libs();
     231 
     232  //načíst knihovny
     233  $this->load_libs();
     234 
     235  //zavolat inicializační metody po načtení knihoven
     236  $this->enviroment->post_libs();
     237 
     238  $this->init_vars();
     239 }

这个类是正确启动的,通过这个(这个EXACT代码适用于我们的许多网站,只是这个突然停止工作):

$aplication = Enviroment::get_aplication('prod');
$aplication->run();

这会引发以下错误(请注意行号):

Notice: Trying to get property of non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 225
Notice: Trying to get property of non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 228
Notice: Trying to get property of non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 230
Fatal error: Call to a member function pre_libs() on a non-object in /var/www/vhosts/e/example.cz/data/www/web/libsf/enviroment/enviroment.php on line 230

(我认为第225行的包含失败是因为$这是“不是对象”......)。 我在CentOS 5.5上运行PHP5.3.3。 当我重新启动apache时,一切似乎都可以正常工作一段时间(五分钟,两小时,七秒......)然后它又开始抛出这些错误。

任何帮助表示感谢。

修改 环境类构造函数:

private function __construct($mode)
 {
  $this->mode = $mode;

  //vygenerovat unikátní hash
  mt_srand((double) microtime() * 1000000);
  $this->hash = md5(uniqid(mt_rand(), TRUE)) . rand(0, 99999999);
 }

Get_application方法:

 public static function get_aplication($mode = 'auto')
 {
  if ($mode == 'auto') {
   //nastavit produkční mod
   $mode = 'prod';

   //rozpoznat typ developerského módu
   if ($_SERVER['SERVER_ADDR'] == '127.0.0.1' || preg_match('/^localhost/', $_SERVER['HTTP_HOST']) || $_GET['env_mode'] == 'developer') {
    $mode = 'dev';
   }
  }
  return self::$enviroment_obj = new Enviroment($mode);
 }

0 个答案:

没有答案