php - json_encode 不响应 getJson

标签 php jquery ajax json getjson

我有一个 html 页面,它会发送 json 请求以从服务器获取数据[通过 php-mysql]。我看到没有收到回复。我尝试通过 fiddler 进行调试,可以看到“响应不包含有效的 json 文本。

我的代码如下

html

<!DOCTYPE html>
<html>
<script src="http://code.jquery.com/jquery-latest.js" 
        type="text/javascript">
</script>

<script type="text/javascript">
function populateFruitVariety() {

    $.getJSON('serverside.php', 
               {fruitName:$('#fruitName').val()}, 
               function(data)  {

    var select = $('#fruitVariety');

    if(select.prop) {
        var options = select.attr('options');
    } else {
        var options = select.attr('options');
    }

    $('option', select).remove();

    $.each(data, function(val, text) {
        options[options.length] = new Option(text, val);
    });
    });
}

$(document).ready(function() {
    populateFruitVariety();
    $('#fruitName').change(function() {
        populateFruitVariety();
    });
});

</script>

<form>
    Fruit:
    <select name="name" id="fruitName">
        <option>Apple</option>
        <option>Banana</option>
        <option>Orange</option>
        <option>Pear</option>
    </select>
    Variety:
    <select name="variety" id="fruitVariety">
    </select>
</form>
</html>

服务器端.php

<?php
header('Content-type: application/json');

$host="localhost";
$username="root";
$password="";
$database="db_common";
$table_fruit_info = "fruit_info";
$tc_fruit_id = "fruit_id";
$tc_fruit_index = 'fruit_index';

$con = mysql_connect("$host", "$username", "$password") 
       or die(mysql_error());
mysql_select_db("$database") or die(mysql_error());

if(isset($_GET['fruitName'])) {
    $fruit_id = $_GET['fruitName'];
    $result = mysql_query("SELECT * FROM $table_fruit_info
                WHERE $tc_fruit_id='$fruit_id'");
    while($rows = mysql_fetch_array($result))
    {
        $ret_fruitIndex = $rows[$tc_fruit_index];
    }
}
echo json_encode($ret_fruitIndex);
?>

感谢您的帮助!

最佳答案

看起来 $ret_fruitIndex 只是一个字符串,没有合适的 JSON 代表。在 while 循环中,每次传递都会覆盖此变量的值,我认为这不是您想要做的。

我假设你真的想要这样的东西:

$ret_fruitIndex[] = $rows[$tc_fruit_index];

另一方面,您的代码非常容易受到 SQL 注入(inject)的攻击,并且您也不应该使用已弃用的 mysql_* 函数。我建议使用 mysqli_* 函数、PDO 或更现代、更安全的东西。

关于你的 jQuery:我不确定你在这里做什么:

if(select.prop) {
    var options = select.attr('options');
} else {
    var options = select.attr('options');
}

因为那里的情况没有任何区别。

我也相信您的 each() 函数是错误的。传递给回调函数的参数将是数据的索引值和该索引的值。

您的逻辑应该是删除所有选项,而不是根据数据添加新选项,所以我不知道为什么 options 变量根本参与此回调函数。

关于php - json_encode 不响应 getJson,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14075216/

相关文章:

java - Thymeleaf 、 JQuery 和消息属性

javascript - 在 `.ajax`之外定义一个json解析函数

javascript - 当页面通过 ajax 更改时,如何运行 Greasemonkey 脚本?

php - PHP 函数内的 PDO 查询

php - jQuery 图形插件

javascript - Slick 轮播边缘的淡入淡出效果

javascript - 使用不同的单击事件后,jQuery 单击事件未触发

javascript - console.log JSON 数据?

php - 从过程语句转换为 mysqli 准备语句

php - 如何在 PHP 中对 UTF-8 执行 strtr?