繁体   English   中英

PHP MySql-检查值是否存在

[英]PHP MySql - Check if value exists

需要检查MySql表中是否同时存在EMAIL_ADDRESSACTIVATION_CODE ,如果返回,则返回"Code is valid" ,否则返回"Code is valid" "Code is NOT valid"

目前,它总是返回无效的代码,但是我检查了表中的记录,并且所查询的代码确实存在。

$email = $_POST['email'];
$acticode = $_POST['code'];


$result = mysql_query("SELECT * FROM xActivate WHERE EMAIL_ADDRESS='$email' AND ACTIVATION_CODE='$acticode' LIMIT 1");

 if (mysql_fetch_row($result)) {
    echo 'Code is valid';
} else {
    echo 'Code is NOT valid';
}

但是此代码并不安全:

$email = $_POST['email'];
$acticode = $_POST['code'];


$result = mysql_query("SELECT * FROM xActivate WHERE EMAIL_ADDRESS='$email' AND ACTIVATION_CODE='$acticode' LIMIT 1");
$data = mysql_fetch_row($result);
 if (mysql_num_rows($result) > 0) {
    echo 'Code is valid';
} else {
    echo 'Code is NOT valid';
}

为了保护和防止SQL注入:

$email = mysql_real_escape_string($_POST['email']);
$acticode = mysql_real_escape_string($_POST['code']);

请注意:

http://ca1.php.net/mysql_real_escape_string

警告

自PHP 5.5.0起不推荐使用此扩展,以后将删除。 相反,应使用MySQLi或PDO_MySQL扩展。 另请参见MySQL:选择API指南和相关的FAQ,以获取更多信息。 此功能的替代方法包括:

  mysqli_real_escape_string() PDO::quote() 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM