错误消息是由于一个不幸的事实,即PHP将隐式声明未知令牌为同名的常量字符串。
也就是说,它试图解释这一点(注意缺少的引号):$_POST[department]
在PHP中,唯一有效的方法是在PHP中有一个常量department定义。因此,可悲的是,它没有在此时因致命的错误而死亡,而是发出了这一通知,并表现得好像一个常量是用相同的名称和值定义的:// Implicit declaration of constant called department with value 'department'define('department', 'department');
您可以通过多种方法获得此错误消息,但它们都有相同的根本原因-一个令牌,即能保持不变。
字符串缺少引号:$my_array[bad_key]
这就是在您的例子中问题所在,这是因为您有未被引用的字符串数组键。修复字符串键将修复错误:
改变:$department = mysql_real_escape_string($_POST[department]);...(etc)...
致:$department = mysql_real_escape_string($_POST['department']);...(etc)...
变量丢失美元符号:var_without_dollar
您可能会看到此错误消息的另一个原因是如果您关闭$从变量,或$this->从一个成员那里。以下任何一项都会导致类似的错误消息:my_local; // should be $my_localmy_member; // should be $this->my_member
变量名中的无效字符:$bad-variable-name
如果尝试在变量名中使用不允许的字符-连字符(-)而不是下划线_这是个普通的案子。if (123 === $my_var) {
do_something();}
但这不是:if (123 === $my-var) {
do_something();}
它将被解释为如下所示:if (123 === $my - var) { // variable $my minus constant 'var'
do_something();}
引用类常量而不指定类范围
为了引用类常量,需要使用::,如果你错过了这个,PHP会认为你在说的是一个全局的define().
例:class MyClass {
const MY_CONST = 123;
public function my_method() {
return self::MY_CONST; // This is fine
}
public function my_method() {
return MyClass::MY_CONST; // This is fine
}
public function my_bad_method() {
return MY_CONST; // BUG - need to specify class scope
}}
使用未在此版本的PHP中定义的常量,或在未安装的扩展中定义的常量
有些系统定义的常量仅存在于较新版本的PHP中,例如,用于round()比如PHP_ROUND_HALF_DOWN只存在于PHP5.3或更高版本中。
因此,如果您试图在PHP5.2中使用此特性,请说:$rounded = round($my_var, 0, PHP_ROUND_HALF_DOWN);
您将得到以下错误消息:使用未定义的常量PHP_REAR_CONMIN_DU-假定的‘PHP_ALUT_HAND_DUD’警告(2):循环()