37

我正在尝试使用 AJAX 自动完成功能,但在让两种语言协同工作时遇到了一些问题。

当我只用 1 个 $_POST 替换所有 issets 时,下面的代码段将起作用,但是通过添加另一个 $_POST 我在第 5 行得到一个错误。

<?php 

require_once '../Configuration.php';
if (isset($_POST['search_term'] . $_POST['postcode']) == true && empty ($_POST['search_term'] . $_POST['postcode']) == false) {
$search_term = mysql_real_escape_string($_POST['search_term'] . $_POST['postcode']);
$query = mysql_query("SELECT `customer_name`,`postcode` FROM `Customers` WHERE `customer_name` LIKE '$search_term%' ");
while(($row = mysql_fetch_assoc($query)) !== false) {
    //loop
    echo '<li>',$row['customer_name'] . $row['postcode'] '</li>';
}
}


?>

任何关于为什么抛出此错误的建议将不胜感激。谢谢。

我知道我应该使用 mysqli,我只是想先了解逻辑:)

JS:

Primary.js:

$(document).ready(function() {
$('.autosuggest').keyup(function() {

    var search_term = $(this).attr('value');
    var postcode = $_GET['postcode'];
    //alert(search_term); takes what is typed in the input and alerts it
    $.post('ajax/search.php', {search_term:search_term, postcode:postcode},     function (data) {
        $('.result').html(data);
        $('.result li').click(function() {
            var result_value = $(this).text();
            $('.autosuggest').attr('value', result_value);
            $('.result').html('');

        });
    });
});
});
4

4 回答 4

86

参数isset()必须是变量引用而不是表达式(在您的情况下是连接);但是您可以像这样将多个条件组合在一起:

if (isset($_POST['search_term'], $_POST['postcode'])) {
}

true仅当所有参数isset()都设置且不包含时才会返回null

注意isset($var)isset($var) == true具有相同的效果,因此后者有些多余。

更新

表达式的第二部分使用empty()如下:

empty ($_POST['search_term'] . $_POST['postcode']) == false

由于与上述相同的原因,这是错误的。其实这里不需要empty(),因为到那时你已经检查了变量是否被设置,所以你可以像这样简化完整的表达式:

isset($_POST['search_term'], $_POST['postcode']) && 
    $_POST['search_term'] && 
    $_POST['postcode']

或使用等效表达式:

!empty($_POST['search_term']) && !empty($_POST['postcode'])

最后的想法

您应该考虑使用filter函数来管理输入:

$data = filter_input_array(INPUT_POST, array(
    'search_term' => array(
        'filter' => FILTER_UNSAFE_RAW,
        'flags' => FILTER_NULL_ON_FAILURE,
    ),
    'postcode' => array(
        'filter' => FILTER_UNSAFE_RAW,
        'flags' => FILTER_NULL_ON_FAILURE,
    ),
));

if ($data === null || in_array(null, $data, true)) {
    // some fields are missing or their values didn't pass the filter
    die("You did something naughty");
}

// $data['search_term'] and $data['postcode'] contains the fields you want

顺便说一句,您可以自定义过滤器以检查提交值的各个部分。

于 2013-01-23T09:49:49.097 回答
9

的参数isset()应以逗号 ( ) 分隔,,而不是点号 ( .)。您当前的代码将变量连接成一个参数,而不是将它们作为单独的参数传递。

所以原始代码将变量评估为统一string值:

isset($_POST['search_term'] . $_POST['postcode']) // Incorrect

虽然正确的形式将它们分别作为变量进行评估:

isset($_POST['search_term'], $_POST['postcode']) // Correct
于 2013-01-23T09:48:44.113 回答
8

您只需:

if (!empty($_POST['search_term']) && !empty($_POST['postcode']))

isset && !empty是多余的。

于 2013-01-23T09:50:13.217 回答
2

将php的OR (||)逻辑运算符用于isset()具有多个运算符的php,例如

if (isset($_POST['room']) || ($_POST['cottage']) || ($_POST['villa'])) {

}
于 2014-05-31T13:32:17.737 回答