0

我目前遇到这个问题,想知道为什么...?

错误信息是:

“XMLHttpRequest 无法加载http://www.panoramio.com/wapi/data/get_photos?v=1&key=dummykey&tag=test&offset=0&length=20&minx=-30&miny=0&maxx=0&maxy=150&callback= ?. Origin hxxp://foo. Access-Control-Allow-Origin 不允许使用 bar。test_panoramio.html:59Uncaught SyntaxError: Unexpected token )"

“hxxp://foo.bar”是指我运行脚本的站点。

网站上的“test_panoramio.html”包含以下内容:

var url = "http://www.panoramio.com/wapi/data/get_photos?    
v=1&key=dummykey&tag=test&offset=0&length=20&minx=-
30&miny=0&maxx=0&maxy=150&callback=?";

function myScriptFn()
 {
  if (window.XMLHttpRequest) {
   myAjax = new XMLHttpRequest();
  if ( typeof myAjax.overrideMimeType != 'undefined') {
  myAjax.overrideMimeType('text/xml');
 }
} else if (window.ActiveXObject) {
myAjax = new ActiveXObject("Microsoft.XMLHTTP");
} else {
  alert('The browser does not support the AJAX XMLHttpRequest!!!');
}

myAjax.onreadystatechange = function() 
{
       handleResponse();
} 

myAjax.open('GET', url, true);
myAjax.send(null);

}

function handleResponse()
{
if (myAjax.readyState == 4){    // Response is COMPLETE
    if ((myAjax.status == 200) || (myAjax.status = 304))
    {
            // do something with the responseText or responseXML
             processResults();

     }else{
     alert("[handleResponse]: An error has occurred.");
     }
     }
}

function processResults()
{

 myObj = eval( '(' + myAjax.responseText + ')' );
 ...
 doSomething()
 ...
}

如果直接在浏览器中键入 Panoramio URL,则可以使用。

请你能帮我解决这个问题,我已经没有希望了...... :(

先感谢您,

你的马尔科

4

1 回答 1

1

您遇到的是同源策略,它可以防止通过 XMLHttpRequest 进行跨域请求。如果站点支持是(并且您尝试访问的支持是),则有一种解决方法JSONP。这意味着您只需要一个填充<script>了该参数的标签,如下所示:callback

<script type="text/javascript" src="http://www.panoramio.com/wapi/data/get_photos?v=1&key=dummykey&tag=test&offset=0&length=20&minx=-30&miny=0&maxx=0&maxy=150&callback=myFunction"></script>

还有一个同名的函数:

function myFunction(data) {
  //data is what came back, it's a javascript object
}

您可以在此处测试一个工作示例

于 2010-12-27T12:48:42.663 回答