小编wee*_*rd2的帖子

使用PhoneGap和jQuery的跨域请求不起作用

我正在为Android创建一个PhoneGap应用.为了从(远程)服务器获取数据,我使用jQuery的$ .ajax()函数进行REST调用.你必须知道一些事情:

  • 呼叫类型必须是POST
  • 服务器需要JSON数据(至少用户名和密码)
  • 服务器发回JSON数据

代码:

function makeCall(){
    var url = "http://remote/server/rest/call";

    var jsonData ='{"username":"'+$('#username').val()+'","password":"'+$('#password').val()+'"}';

    $.ajax({
            headers: {"Content-Type":"application/json; charset=UTF-8"},
            type: "POST",
            url: url,
            data: jsonData,
            dataType: "json",
            success: succesFunction,
            error: errorFunction
    });
}
Run Code Online (Sandbox Code Playgroud)

但是,这不起作用.当我使用Firebug查看服务器响应时,什么都没有.使用TcpTrace,我可以看到请求的标头.而不是预期的POST方法,有一个OPTIONS方法,添加了一些奇怪的标题.

OPTIONS /remote/server/rest/call HTTP/1.1
Host: localhost:8081
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:11.0) Gecko/20100101 Firefox/11.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: nl,en-us;q=0.7,en;q=0.3
Accept-Encoding: gzip, deflate
Connection: keep-alive
Origin: null
Access-Control-Request-Method: POST
Access-Control-Request-Headers: content-type
Pragma: no-cache
Cache-Control: no-cache
Run Code Online (Sandbox Code Playgroud)

我知道这与进行跨域请求有关,但我不知道如何解决问题.我尝试了一些方法来解决它,但没有结果:

该问题还与相同的源策略有关,但这不适用于file://协议PhoneGap用于加载本地html文件.

在我的AndroidManifest.xml文件中,选项

<uses-permission android:name="android.permission.INTERNET" />
Run Code Online (Sandbox Code Playgroud)

已设定.

我现在试图解决这个问题2天,但到目前为止还没有结果.这甚至可能吗?你有什么提示给我,所以我可以继续前进吗?

提前致谢!

ajax jquery cross-domain cordova

19
推荐指数
2
解决办法
4万
查看次数

标签 统计

ajax ×1

cordova ×1

cross-domain ×1

jquery ×1