12

所以这是我的电话:

   $.ajax({
       url: url,
       headers: { 'Access-Control-Allow-Origin': '*' },
       crossDomain: true,
       success: function () { alert('it works') },
       error: function() {alert('it doesnt work')},
       datatype: 'jsonp'
   });

我的网址是合法的。你会注意到我没有数据集。我不确定数据类型是否正常工作,因为它实际上返回了 xml,但我也尝试过。它是对sportsdata api的调用。在该站点上,他们向您显示了 x-originating-ip 的请求标头,因此我尝试了access-control-allow-origin所在的位置。

所有这些仍然返回访问控制错误。如果我设置它,我不清楚它是什么数据,所以我暂时省略了它。我尝试了一些不同的东西,我用谷歌搜索,我明白为什么我会收到错误。我不知道如何解决它。我试图不必问,但如果有人可以解释或告诉我方法,那将不胜感激

4

2 回答 2

8

http://encosia.com/using-cors-to-access-asp-net-services-across-domains/

有关跨域资源共享的更多详细信息,请参阅上面的链接。

您可以尝试使用JSONP。如果 API 不支持 jsonp,您必须创建一个服务作为 API 和客户端之间的中间人。就我而言,我创建了一个 asmx 服务。

下面的示例:

阿贾克斯调用:

$(document).ready(function () {
        $.ajax({
            crossDomain: true,
            type:"GET",
            contentType: "application/json; charset=utf-8",
            async:false,
            url: "<your middle man service url here>/GetQuote?callback=?",
            data: { symbol: 'ctsh' },
            dataType: "jsonp",                
            jsonpCallback: 'fnsuccesscallback'
        });
    });

将返回 jsonp 的服务(asmx):

[WebMethod]
    [ScriptMethod(UseHttpGet = true, ResponseFormat = ResponseFormat.Json)]
    public void GetQuote(String symbol,string callback)
    {          

        WebProxy myProxy = new WebProxy("<proxy url here>", true);

        myProxy.Credentials = new System.Net.NetworkCredential("username", "password", "domain");
        StockQuoteProxy.StockQuote SQ = new StockQuoteProxy.StockQuote();
        SQ.Proxy = myProxy;
        String result = SQ.GetQuote(symbol);
        StringBuilder sb = new StringBuilder();
        JavaScriptSerializer js = new JavaScriptSerializer();
        sb.Append(callback + "(");
        sb.Append(js.Serialize(result));
        sb.Append(");");
        Context.Response.Clear();
        Context.Response.ContentType = "application/json";
        Context.Response.Write(sb.ToString());
        Context.Response.End();         
    }
于 2013-10-17T10:42:33.043 回答
0

在我的工作中,我们在不同的端口号上有我们的 RESTful 服务,数据驻留在一对 AS400 上的 db2 中。我们通常使用$.getJSONAJAX 方法,因为它使用 很容易返回 JSONP 而?callback=?不会出现任何 CORS 问题。

data ='USER=<?echo trim($USER)?>' +
         '&QRYTYPE=' + $("input[name=QRYTYPE]:checked").val();

        //Call the REST program/method returns: JSONP 
        $.getJSON( "http://www.stackoverflow.com/rest/resttest?callback=?",data)
        .done(function( json ) {        

              //  loading...
                if ($.trim(json.ERROR) != '') {
                    $("#error-msg").text(message).show();
                }
                else{
                    $(".error").hide();
                    $("#jsonp").text(json.whatever);

                }

        })  
        .fail(function( jqXHR, textStatus, error ) {
        var err = textStatus + ", " + error;
        alert('Unable to Connect to Server.\n Try again Later.\n Request Failed: ' + err);
        });     
于 2016-05-25T17:06:48.167 回答