我的Ajax跨域请求在IE 9中失败并显示“拒绝访问”。我已阅读了有关此主题的几篇文章,并且AFAIK应该可以使用。
async
,jsonp
和crossdomain
,cache
是false
。这些是我找到的先决条件。 jQuery.support.cors
是真的Access-Control-Allow-Origin:*
(SO)那么为什么拒绝访问会导致失败?任何的想法?可能是因为我的代码是从“JavaScript”库中调用的,而不是页面上的<script></script>
标记吗?
我错过了什么?
// The code is part of an object's method (prototype)
// code resides in a library "Mylib.js"
$.ajax({
type: 'GET',
url: url,
cache: false,
async: true,
crossdomain: true, // typo, crossDomain, see my answer below
datatype: "jsonp", // dataType
success: function (data, status) {
if (status == "success" && !Object.isNullOrUndefined(data)) { ... }
},
error: function (xhr, textStatus, errorThrown) {
// access denied
}
});
- 编辑 - 根据Robotsushi的评论,进一步研究---
XDomainRequest
jQuery.support.cors = true
),我最终会遇到“No Transport”例外。jQuery处理这个问题的方式,似乎是围绕下面的代码,但在我的特定情况下没有调用,不知道为什么?
//绑定脚本标记黑客传输 jQuery.ajaxTransport(“script”,function(s){
// This transport only deals with cross domain requests
if ( s.crossDomain ) {
2010年的类似情况:Jquery $.ajax fails in IE on cross domain calls但是,这应该是后来的jQuery版本解决的。
答案 0 :(得分:5)
好的,现在就开始工作。我身边的几个错误:
crossDomain: true, dataType: "jsonp"
,错字 - 错过大写字母。考虑到所有事情,它都有效。所以我的个人清单是:
json
(例如,使用Chrome,FF或IE10)。确保设置了响应标头:Access-Control-Allow-Origin:*
jsonp
,请检查:async: true
,jsonp
和crossdomain: true
,cache
为false
,jQuery.support.cors
为{ {1}}这些是我找到的先决条件。 true
响应是函数调用(JSON wrapped in function),不是“只是普通的”JSON数据。答案 1 :(得分:3)
我有一个类似的问题,试图访问我存储在Google云端存储上并使用jQuery的ajaxing访问的一些json。这在Chrome和Firefox中运行良好,但在IE(9及以下)测试时,我收到了“拒绝访问”消息。
我解决这个问题的方法是明确地使用jsonP:
(function (o) {
variableName = [json];
}(window.[nameSpace] = window.[nameSpace]|| {}));
在html文件的标记内包含javascript文件的URL,例如
<script type="application/javascript" src="[url to javascript file]"></script>
希望这会有所帮助:)
答案 2 :(得分:2)
IE要求您使用XDomainRequest
代替XHR进行跨网站。
您可以查看easyXDM,这是一个js库,可以为您提取此过程的摘要。
或者看看: