0

AJAXを使用して複数のサーバーからリソースにアクセスしようとしていますが、次の問題が発生しています。

XMLHttpRequest cannot load http://first.mydomain.com. Origin http://second.mydomain.com is not allowed by Access-Control-Allow-Origin.

次のコードで

    for ( i in domains )
    {
        var url = 'http://'+domains[i]+'/mgmt/json/queue_status.php';
        requests[i]=new request(url);
        break;
    }

    function request(url)
    {
        var queues = {};
        http_request = new XMLHttpRequest();
        http_request.open("GET", url, true, 'username', 'password');
        http_request.onreadystatechange = function () {
            var done = 4, ok = 200;
            if (http_request.readyState == done && http_request.status == ok) {
                queues = JSON.parse(http_request.responseText);
                var queuesDiv = document.getElementById('queues');
                print_queues(queues, queuesDiv);                
            }
        }
        http_request.send(null);
    }

リクエストされている回答ページに以下を追加しました。

header('Access-Control-Allow-Origin: *');

リクエスターにも明示的に名前を付けようとしましたが、成功しませんでした。

ありがとう

PS:上記のコードは完全ではありませんが、ホストサーバーのリソースを要求するだけで正常に機能します。

4

1 に答える 1

0

ユーザー名とパスワードはクロス オリジン リクエストでは使用できません。

ユーザーまたはパスワードのいずれかが引数として渡され、url のオリジンが XMLHttpRequest オリジンと一致しない場合、INVALID_ACCESS_ERR 例外をスローします。

ソース: http://www.w3.org/TR/XMLHttpRequest2/#the-open-method

代わりに、パスワードとユーザー名を get 変数として渡すだけです。

于 2011-09-27T16:06:14.013 に答える