jQuery AJAX 从 localhost 加载 JSONP,但不返回数据


jQuery AJAX loads JSONP from localhost but doesn't return data

我正在尝试从我的本地主机加载一些JSONP。我有一个 PHP 网络应用程序,如果提供,它会返回带有回调的 JSON。返回的 JSON 是 100% 有效的(使用 JSON 验证器检查)。网址如下所示:

http://localhost/backstage/public/data/acties?callback=?

现在,当我尝试使用 jQuery AJAX 加载此数据时,它会给我一个警报,说"错误",暗示加载失败。

var url = "http://localhost/backstage/public/data/acties";
$("#debug").click(function() {
    console.log("getting data from " + url);
    $.ajax({
       type:'GET',
       url: url,
       dataType:'jsonp',
       success: function(data){
           alert('loaded');
       },
       error: function(data){
           alert('error');        
       }
    });
});

但是,当我转到网络选项卡时,我看到已请求:

http://localhost/backstage/public/data/acties?callback=jQuery19008035339566413313_1358941083680&_=1358941083681

并且该文件中的内容是有效的JSON(再次,我使用JSON验证器对其进行了验证)。数据似乎没有出现在我在 JavaScript 中的数据变量中。

作为参考,这是我的PHP(Zend 1.12)代码:

public function actiesAction()
    {
        $data = new Application_Model_DbTable_Actie();
        $data = $data->fetchAll();
        $callback = htmlspecialchars($_GET["callback"]);
        $data = Zend_Json::encode($data);
        echo $callback.'('.$data.');';     
    }

这是你去的时候得到的JSONP

http://localhost/backstage/public/data/acties?callback=?
-

-> http://pastebin.com/tazcUQAW

有谁知道如何解决这个问题?

我发现了错误:我的基本布局仍然在响应中包含 HTML 代码。我按照在ZEND(第二个答案)中处理JSONP调用的步骤进行操作,现在它运行良好。无论如何,感谢您的帮助!