5

我使用以下输入到 mongoDB 执行 curl 命令。

curl --data 'cmd={"geoNear" : "items", "near":[6.8590845,79.9800719]}' 'http://72.123.xxx.xxx:27080/weather/_cmd'

我想使用 jsonp 或 json 执行它并获得响应。我在 jsonp 请求下尝试过。

var url =  "http://72.123.xxx.xxx:27080/weather/_cmd";
$.getJSON(url + "?callback=?",
    {
        cmd:{"geoNear" : "items", "near": 6.8590845,79.9800719]}
    },
    function(tweets) { }
);

我没有从控制台得到任何东西。请帮我解决一下这个。谢谢。

4

2 回答 2

5

最后我想出了解决方案。

$.ajax({
    url: '/weather/_cmd',
    type:'POST',
    dataType: 'json',
    crossDomain : true,
    data: {
        cmd: JSON.stringify({
            "geoNear" : "items",
            "near": [6.8590845,79.9800719]
        })
    },
    success: function(res) {
        //do stuff with res
    }
});

ProxyPass /weather http://72.123.xxx.xxx:27080/weather/_cmd
ProxyPassReverse /weather http://72.123.xxx.xxx:27080/weather/_cmd

将上述代理通行证添加到您的 Apache 并尝试此操作。它会起作用的。问题是您无法使用 jsonp 传递 POST 请求。mongo 我们需要 POST 请求。这是一种方法。:D 我对它进行了测试,并且非常适合我。它不会接受 json,您必须将其作为字符串传递。

于 2013-08-20T10:49:11.407 回答
1

您可能一无所获,因为您的 MongoDB 实例不支持 JSONP(并且您需要它,因为通常您不能执行跨域 ajax 请求)或者您的查询不正确(显然您必须使用?jsonp=而不是?callback=)。

一种方法是直接使用 JSONP。由于您使用的是 jQuery,您可以尝试这样的事情:

$.ajax({
    url: 'http://72.123.xxx.xxx:27080/weather/_cmd',
    dataType: 'jsonp',
    jsonp: 'jsonp', // <-- the name used in '?jsonp=' part of url
    data: {
        cmd: {
            "geoNear" : "items",
            "near": [6.8590845,79.9800719]
        }
    },
    success: function(res) {
        console.log(res);
    }
});

根据这个 StackOverflow 答案:

MongoDB 有本地 REST 接口吗?

如果您使用--jsonp选项触发 MongoDB 实例(为了启用对 JSONP 的支持),它应该可以工作。我还没有尝试过。

另外可能还有其他问题。例如,数据库可能会简单地断开连接,您可能没有权限等。通常从客户端直接连接到数据库从来都不是一个好主意。您应该使用 Web 服务器作为中间人。

于 2013-08-09T06:37:28.950 回答