Dojo实现跨源(CROS)请求
2015-06-16 09:52
465 查看
今天在做web的跨源请求数据的时候,遇到了问题,本人使用IE10可以直接使用dojo/_base/xhr进行跨源请求,但是使用firefox的时候竟然报错,错误信息如下
已阻止跨源请求:同源策略禁
4000
止读取位于 http://****************?dojo.preventCache=1434419405262 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。
已阻止跨源请求:同源策略禁止读取位于 http://****************?dojo.preventCache=1434419405262 的远程资源。(原因:CORS 请求失败)。
在网上查了一下说是跨源请求数据的问题,dojo代码如下
require(["dojo/_base/xhr"], lang.hitch(this, function(xhr){
xhr.get({
url: "url,
preventCache: true,
content: {},
timeout: 100000,
load: lang.hitch(this, function(response){
var json = dojo.fromJson(response);
//TODO
}),
error: dojo.hitch(this, function(response, ioArgs){
})
});
按照上面的写法,在firefox中就报了上面的那个错误,如果用jQuery的getJson不管是IE或者是firefox都没有问题,最后只能求助Google,在翻上越岭之后,终于发现了一条有用的信息,就是在xhr的请求头加入
headers: {
"X-Requested-With": null//跨源请求数据需要添加此项
}
就解决了问题。
至于原理还不是很明白,如果有什么错误或解释大家可以回复。
问题补充:
前台js部分如上设置后,后台在接收请求的时候需要添加如下代码,红色部分
java代码:
@RequestMapping(value="/yourFunc")
public void yourFunc(HttpServletRequest req, HttpServletResponse resp) throws Exception {
resp.setHeader("Access-Control-Allow-Origin", "*");
resp.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE");
resp.getWriter().println(JSONObject.fromObject(null));
}
已阻止跨源请求:同源策略禁
4000
止读取位于 http://****************?dojo.preventCache=1434419405262 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。
已阻止跨源请求:同源策略禁止读取位于 http://****************?dojo.preventCache=1434419405262 的远程资源。(原因:CORS 请求失败)。
在网上查了一下说是跨源请求数据的问题,dojo代码如下
require(["dojo/_base/xhr"], lang.hitch(this, function(xhr){
xhr.get({
url: "url,
preventCache: true,
content: {},
timeout: 100000,
load: lang.hitch(this, function(response){
var json = dojo.fromJson(response);
//TODO
}),
error: dojo.hitch(this, function(response, ioArgs){
})
});
按照上面的写法,在firefox中就报了上面的那个错误,如果用jQuery的getJson不管是IE或者是firefox都没有问题,最后只能求助Google,在翻上越岭之后,终于发现了一条有用的信息,就是在xhr的请求头加入
headers: {
"X-Requested-With": null//跨源请求数据需要添加此项
}
就解决了问题。
至于原理还不是很明白,如果有什么错误或解释大家可以回复。
问题补充:
前台js部分如上设置后,后台在接收请求的时候需要添加如下代码,红色部分
java代码:
@RequestMapping(value="/yourFunc")
public void yourFunc(HttpServletRequest req, HttpServletResponse resp) throws Exception {
resp.setHeader("Access-Control-Allow-Origin", "*");
resp.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, PUT, DELETE");
resp.getWriter().println(JSONObject.fromObject(null));
}
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- JavaScript演示排序算法
- jQuery Ajax 跨域调用
- jquery教程靠边站,一分钱不花让你免费学会jquery
- JQuery+Strusts1.x无刷新登录
- JQuery 初体验(建议学习jquery)
- Jquery实现的table最后一行添加样式的代码
- jQuery 练习[一] 学习jquery的准备工作
- jquery获得页面元素的坐标值实现思路及代码
- 麻雀虽小五脏俱全 Dojo自定义控件应用
- 自己开发Dojo的建议框架
- jquery如何实现在加载完iframe的内容后再进行操作
- jquery $.ajax()取xml数据的小问题解决方法
- jQuery '行 4954 错误: 不支持该属性或方法' 的问题解决方法
- Jquery 表单取值赋值的一些基本操作
- jQuery中的常用事件总结
- 23个超流行的jQuery相册插件整理分享
- 影响jQuery使用的14个方面
- jQuery 仿百度输入标签插件附效果图
- jQuery学习笔记之jQuery的动画