PHP正在日志中写入此错误:“注意:使用未定义的常量”。
日志错误:
PHP Notice: Use of undefined constant department - assumed 'department' (line 5)
PHP Notice: Use of undefined constant name - assumed 'name' (line 6)
PHP Notice: Use of undefined constant email - assumed 'email' (line 7)
PHP Notice: Use of undefined constant message - assumed 'message' (line 8)
相关代码行:
$department = mysql_real_escape_string($_POST[department]);
$name = mysql_real_escape_string($_POST[name]);
$email = mysql_real_escape_string($_POST[email]);
$message = mysql_real_escape_string($_POST[message]);
这是什么意思,为什么我会看到它?
答案 0 :(得分:200)
您应引用数组键:
$department = mysql_real_escape_string($_POST['department']);
$name = mysql_real_escape_string($_POST['name']);
$email = mysql_real_escape_string($_POST['email']);
$message = mysql_real_escape_string($_POST['message']);
原样,它正在寻找名为department
,name
,email
,message
等的常量。当它找不到这样的常量时,PHP(奇怪的是)把它解释为一个字符串('部门'等)。显然,如果你稍后定义了这样的常量,这很容易破坏(虽然使用小写常量是不好的风格)。
答案 1 :(得分:72)
错误消息是由于PHP将隐式声明未知标记为同名的常量字符串而导致的错误消息。
也就是说,它试图解释这个(注意缺少的引号):
$_POST[department]
这是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_local
my_member; // should be $this->my_member
$bad-variable-name
如果您尝试在变量名中使用不允许的字符,则会产生类似但更微妙的问题 - 连字符(-
)而不是下划线_
将是常见情况。
例如,这是好的,因为underscores are allowed in variable names:
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中,例如round()
的模式选项常量,例如PHP_ROUND_HALF_DOWN
仅存在于PHP 5.3或更高版本中。
因此,如果您尝试在PHP 5.2中使用此功能,请说:
$rounded = round($my_var, 0, PHP_ROUND_HALF_DOWN);
您会收到以下错误消息:
使用未定义的常量PHP_ROUND_HALF_DOWN - 假设 'PHP_ROUND_HALF_DOWN'警告(2):round()
的参数计数错误
答案 2 :(得分:6)
你可能忘了使用""
。
例如:
$_array[text] = $_var;
更改为:
$_array["text"] = $_var;
答案 3 :(得分:1)
使用post变量的正确方法是
<?php
$department = $_POST['department'];
?>
使用单引号(')
答案 4 :(得分:1)
server.ssl.key-store
注意:使用未定义的常量测试 - 在第3行的D:\ xampp \ htdocs \ sp \ test \ envoirnmentVariables.php中假定为'test' 测试信息
答案 5 :(得分:1)
插入单引号。
实施例
let (|LT|EQ|GT|) (x, y) =
if x < y then LT
elif x = y then EQ
else GT
let areCoPrimes x y =
let rec aux (x, y) =
match x, y with
| 0, _ | _, 0 -> false
| LT -> aux (x, y - x)
| EQ -> x = 1
| GT -> aux (x - y, y)
aux (abs x, abs y)
答案 6 :(得分:1)
您错过了在数组键周围放置单引号:
$ _ POST [电子邮件]
应该是:
$ _ POST [ '电子邮件']
答案 7 :(得分:0)
我不确定使用代码点火器是否有任何区别,我使用“”作为名称并且效果很好。
$department = mysql_real_escape_string($_POST["department"]);
$name = mysql_real_escape_string($_POST["name"]);
$email = mysql_real_escape_string($_POST["email"]);
$message = mysql_real_escape_string($_POST["message"]);
的问候,
豪尔赫。
答案 8 :(得分:0)
看起来预定义的提取常量随着MySQL扩展而消失,所以我们需要在第一个函数之前添加它们...
//预定义获取常量
define('MYSQL_BOTH',MYSQLI_BOTH);
define('MYSQL_NUM',MYSQLI_NUM);
define('MYSQL_ASSOC',MYSQLI_ASSOC);
我测试过并且成功了。