当我的PHP版本更新到5.4(示例1.8.0)时,我看到一个致命错误:
致命错误:无法在第5行上的C:''examplep''htdocs''vs''classes''Session.class.php中重新声明类会话
此问题是否与更新PHP
版本有关?
session.class.php:
<?php
defined('_VALID') or die('Restricted Access!');
class Session
{ // <-- This Is Line 5
private static $_sess_db;
public static function open() {
global $config;
if (self::$_sess_db = mysql_connect($config['db_host'], $config['db_user'], $config['db_pass'])) {
return mysql_select_db($config['db_name'], self::$_sess_db);
}
return false;
}
public static function close() {
return mysql_close(self::$_sess_db);
}
public static function read($session_id) {
$sql = sprintf("SELECT `session_data` FROM `sessions` WHERE `session_id` = '%s'", mysql_real_escape_string($session_id));
if ($result = mysql_query($sql, self::$_sess_db)) {
if (mysql_num_rows($result)) {
$record = mysql_fetch_assoc($result);
return $record['session_data'];
}
}
return '';
}
public static function write($session_id, $session_data)
{
$sql = sprintf("REPLACE INTO `sessions` VALUES('%s', '%s', '%s')", mysql_real_escape_string($session_id),
mysql_real_escape_string(time()), mysql_real_escape_string($session_data) );
return mysql_query($sql, self::$_sess_db);
}
public static function destroy( $session_id )
{
$sql = sprintf("DELETE FROM `sessions` WHERE `session` = '%s'", $session_id);
return mysql_query($sql, self::$_sess_db);
}
public static function gc($max) {
$sql = sprintf("DELETE FROM `sessions` WHERE `session_expires` < '%s'", mysql_real_escape_string(time() - $max));
return mysql_query($sql, self::$_sess_db);
}
}
似乎不止一次包含session.class.php。。。或者在包含的另一个文件中声明类Session。
正如@cegault所说:include_once
和require_once
可以用来防止这种情况。
但最好确保只包含一次文件(较少使用内存)。CCD_ 4和CCD_。
尝试将类包装在if
语句中,如下所示:
if (class_exists('Session') != true) {
class Session { ... }
}
如果你的代码结构复杂/很大,这将防止错误
请参阅class_exists()
文档