JSON查询问题


Issue with a JSON Query

I使用json onclick脚本来触发php函数。我用调用php函数

$('#dtable').on('click', '[name=option3]', function () {
    var select = $(this);
    var id = select.attr('id');
    $.post('index.php/stop/'+id+'', function(json) {
            if (json && json.status) {
                $("#failure").show().delay(2500).fadeOut(1500);
            } else {
                $("#success").show().delay(2500).fadeOut(1500);
            }
        }
    );
} );

如果项目是触发器,他会在我的index.php 中调用一个slim属性

$admin->slim->post('/stop/:action', function($action) use ($admin) {
    $admin->slim->contentType('application/json');
    echo json_encode($admin->cont->Stop($action));

之后,他触发了功能

function Stop($action) {
    $port = $action;
    $connection = @fsockopen($this->cfg->base_host, $port, $errno, $errstr, 1);
    if (!$connection) {
        return false;
    } else {
        $pid = $this->db->query("SELECT pid FROM testdb WHERE port='" . $port . "'", SQL_ALL, SQL_ASSOC);
        if ($pid == "") {
            return false;
        } else {
                  ......
                }
            }
        }
    }
}

唯一的问题是json的答案总是成功的但是函数没有返回true或false

有人知道我做错了什么吗?或者有人能给我一些建议吗。

  • 添加了有关该功能的更多信息

在使用if (json && json.status)之前先使用alert(json);,看看您得到了什么。我确信json不是你所期望的。似乎是json == false(因为函数Stop()返回false),并且没有json.status——或者可能是Stop函数的其余部分返回了更多内容。