jQuery跨域ajax请求总是出错
我正在尝试创建一个简单的 jQuery 移动应用。我的设置如下:
- jQuery 客户端运行在 localhost:9090/myapp。
- 我的服务器运行在 localhost:9010/paperboy。
- 因为我使用的是 Windows,所以在服务器端我使用了一个简单的服务器,这个服务器是用bottle这个 Python 微框架创建的。
- 服务器在收到请求时返回 JSON 数据,我可以在 Chrome 或 Firefox 中清楚地看到这些数据。
- 我已经验证了我的响应,它是有效的 JSON。
我遇到的问题是,我希望我的客户端能够读取服务器返回的 JSON 数据。
但是由于跨域问题,它无法做到这一点。
这是我客户端的 ajax 代码:
$.ajax({
url: "http://localhost:9010/paperboy/toi",
type:"GET",
data:$(this),
dataType:"jsonp",
//jsonp:"callback", no support on the server
success:function(result){
console.log("ajax result: " + result);
},
error:function(e){
console.log("Error :" + e);
}
});
而我的 bottle 服务器代码是:
from bottle import route, run, template, response
from paperboy import getToiNews
''' call http://localhost:9010/paperboy/toi in browser'''
@route('/paperboy/:source')
def index(source='All'):
print "requesting news list for %s" % source
resultJson = getToiNews()
response.content_type = "application/javascript"
return resultJson
run(host='localhost', port=9010)
不过在运行应用时,我最开始遇到了“ajax 源策略错误”,但在我给服务器添加了内容类型后,这个错误很快就消失了。
现在 ajax 调用没有错误,但总是调用“错误”处理程序。我尝试了各种组合,但都没有成功。有一件事我搞不明白,就是如何给我的服务器添加 jsonp 支持。
我非常感谢在这方面的任何帮助,提前谢谢大家的帮助。
谢谢。