PhoneGap:从外部源加载数据

时间:2012-05-15 16:17:08

标签: javascript android cordova

我想创建一个带有phonegap的网络应用程序(我正在尝试使用Android模拟器),但我遇到了“相同域策略”的问题:是否有任何方法可以禁用此限制。我需要从外部服务器加载html / json数据(不是我自己的,所以我不能修改它),但是当我尝试获取数据时,JQuery返回一个未定义的对象。这是我的代码:

的index.html

<!DOCTYPE html>
<html>
    <head>
        <meta charset="ISO-8859-1">
        <title>Title</title>
        <script type="text/javascript" src="js/jquery.min.js"></script>
        <script type="text/javascript">
            $.ajaxSetup ({
                cache: false
            });
            var ajax_load = "<img src='img/load.gif' alt='loading...' />";
            var jsonUrl = "external url";
                $("#result").html(ajax_load);
                $.getJSON(jsonUrl, function(json) {
                    var result = json.responseData;
                    $("#data").html("Result: " + result);
                });
        </script>
    </head>
    <body>
        <div id="data"></div>
    </body>
</html>

PhoneGapTestActivity

public class PhoneGapTestActivity extends DroidGap {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        super.loadUrl("file:///android_asset/www/index.html");
    }
}

在线搜索并阅读其他问题,我尝试在文件 phonegap.xml

中设置白名单
<?xml version="1.0" encoding="UTF-8"?>
<phonegap>
    <access origin="*" subdomains="true" />
</phonegap>

但我得到的是:“结果:未定义”。 非常感谢!

编辑:经过多次尝试后,我注意到请求有效(我收到了数据),但是在访问json数据内容时出现了一些问题,但现在可以了! 谢谢你的所有答案。

3 个答案:

答案 0 :(得分:0)

没有理由不这样做。我不是jQuery的大用户,但是你可以设置一些东西来启用CORS。

A CORS POST request works from plain javascript, but why not with jQuery?

答案 1 :(得分:0)

试试这个.. 我不知道它是否适用于这种情况,但它对我有效。

<?xml version="1.0" encoding="utf-8"?>
<phonegap>
<access origin="http://127.0.0.1*"/>
<log level="DEBUG"/>
</phonegap>

答案 2 :(得分:0)

经过多次尝试,我注意到请求有效(我收到了数据),但访问json数据内容时出现了一些问题。