繁体   English   中英

Windows Phone 7 / IE9 jQuery ajax“访问被拒绝”

[英]Windows Phone 7/IE9 jQuery ajax “Access is denied”

我试图在Windows Phone 7.5上的jQuery中使用以下代码。 每次我尝试对xml提出ajax请求时,都会从错误处理程序中返回“访问被拒绝”。 不幸的是,JSONP无法在这种情况下工作,因为我需要的数据仅是XML。 我不确定如何解决此问题。

编辑:我应该指出,该代码在Chrome和Safari上运行良好。 我没有Windows计算机可以在IE上进行测试。 编辑2:在IE9上测试,但有相同的错误。

javascript:

function loadData(index) {
$.support.cors = true;
$.mobile.allowCrossDomainPages = true;
   $.ajax({
       url: "http://foo.bar/some.xml",
       dataType: "xml",
       success: parseData,
       error: function(XMLHttpRequest, textStatus, errorThrown) { 
         alert("Status: " + textStatus); alert("Error: " + errorThrown); 
       } 
   });
};

PHP代理来获取XML

<?php
header('Content-type: text/xml');
header("Access-Control-Allow-Origin: *");
header("Access-Control-Allow-Methods: POST, GET, OPTIONS");

$intme = date('YmdHis');
$start = $_GET['ind'];
$url = "http://some.data.source/data.xml";
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$output = curl_exec($ch);
curl_close($ch);
echo $output;
?>

不知道普通的JQuery怎么样,但是当我使用phonegap时,我遇到了同样的问题并编写了此代码:

在发出AJAX请求之前,您必须通过设置以下内容来允许跨域请求和核心支持:

jQuery.support.cors = true;
$.mobile.allowCrossDomainPages = true;

这些必须在特定的电话间隙功能“ DeviceReady”中设置,例如:

document.addEventListener('deviceready', function () {
            jQuery.support.cors = true;
            $.mobile.allowCrossDomainPages = true;
            $.ajax({
                url: "www/about.txt",
                dataType: 'text'
            }).done(function (result) {
                    alert(result);
                });
            });

2.2。 网址

制作面向Windows Phone 8的应用程序时,必须在AJAX请求中指定资源的完整路径,例如:url:“ www / about.txt”,

制作面向Windows Phone 8的应用程序时,不得在AJAX请求中指定资源的完整路径,例如:url:“ about.txt”,

2.3。 源文件扩展名

请小心使用未知的扩展名文件,例如模板扩展名* .tpl或类似文件。 有时AJAX不喜欢它们,我建议使用简单的* .txt和* .html扩展名。

3. getJSON

$ .getJSON以某种方式在Windows Phone上不起作用,例如:

 $.getJSON('www/jsonfiles/jsonfile.txt',
              function(data, status, jqXHR) {
                if(status == "success") {
                    alert(data);
                }
              });

您可以将其替换为AJAX请求,如下所示:

 $.ajax({
        url: 'www/jsonfiles/jsonfile.txt',
        dataType: 'text'
    }).done(function (result) {
        Alert( JSON.parse(result));
    });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM