以jsonp发送请求,使用jQuery 1.5将响应解释为文本

时间:2012-02-11 09:02:17

标签: jquery cross-domain jsonp cors

简短的问题:有没有办法向服务器发出jsonp请求,捕获请求,但不能将其解析为javascript?我在jQuery 1.5中使用dataType:“jsonp text”,但它无效。

我正在尝试使用jsonp通过AJAX访问跨域URL。问题是另一个域(我大学的目录列表)很老,我怀疑服务器是否支持jsonp。

  • 在Firefox中,我收到“XML标记名称不匹配(预期的META)”错误。在chrome中我得到一个“Uncaught SyntaxError Unexpected token<”两者都指向与我的AJAX请求相对应的文件。错误回调中的错误字符串是“parsererror”。
  • 我无法进行正常的AJAX调用 - 当我将数据类型更改为“text”或将其全部删除时,另一个域会抱怨用户未经过身份验证并重定向到登录页面 - 即使我已经登录浏览器端了。当dataType是jsonp时,不会发生这种情况。
  • 我知道服务器需要支持JSONP,我认为不行,但当我将dataType更改为JSONP时,我可以看到响应页面资源显示在Chrome和Firefox中 - 所以服务器实际发送对浏览器的响应(静态HTML网页+一些java脚本) - 包含我想要获取的数据。
  • 问题是jQuery试图将响应解析为javascript,并且失败(因为它不是javascript)。所以数据最终会在浏览器中显示 - 我只需要访问它!
  • 使用dataType:“jsonp text”应该表示发送jsonp请求并将响应解释为文本没有区别 - 仍然是解析错误。

我想要的是:从jsonp请求以纯文本形式访问响应的方法。或者,如果我可以从失败的jsonp请求访问原始响应 - 这也可以。

提前致谢!

代码:

ajax_url = 'https://somesite/?searchTerm='+query+'&searchType=lastname';
var jqxhr = $.ajax({type:"GET",
url: ajax_url,
dataType:"jsonp text",
callback: "whatever",
success:function(responseData) {
   $('div#content').text( responseData.slice(0, 100) );
   dbg(responseData.slice(0,100));
}})
.success(function() { alert("success"); })
.error(function(obj, errStr) { alert("error"); dbg("error: " + errStr + "test: " + test.responseText + this.responseTxt);})
.complete(function() { alert("complete"); });

1 个答案:

答案 0 :(得分:8)

您尝试实现的目标不起作用:只有当服务器在javascript函数调用中正确嵌入响应时,才能使用jsonp。

即使服务器确实将文件发送到浏览器,但由于安全限制,您将无法访问它:您所能做的就是将所述数据作为脚本执行(带有脚本标记)或将其用作样式表(使用链接标记)但是,如果它来自另一个域,您将永远无法检查原始文本中的响应。

我想您试图直接将数据作为xml获取并且失败(意味着该站点不支持CORS)。如果您无法更改服务器端的代码,那么您只有两种选择:

  1. 在您自己的服务器上创建一个隧道响应的代理(您的服务器端脚本发出实际请求并将其发送到浏览器):然后从客户端的角度应用相同域,您将成为能够以XML格式请求数据,
  2. 使用Flash绕过浏览器的安全性(您可以使用flXHR但现在看起来有点过时了。)