关于ajax跨域访问,Access-Control-Allow-Origin 404的简单解决办法

~关于ajax跨域,都是一个老生常谈的问题了,解决方法很多,比较常用的是JSONP方法,JSONP方法是一种非官方方法,而且这种方法只支持GET方式,不如POST方式安全(大家应该都知道微笑)。即使使用jquery的jsonp方法,type设为POST,也会自动变为GET。(实践才是硬道理偷笑


例如:客户端的域名是www.c.com,而请求的域名是www.s.com

如果直接使用ajax访问,会有以下错误

XMLHttpRequest cannot load http://www.server.com/server.php. No 'Access-Control-Allow-Origin' header is present on the requested resource.Origin 'http://www.c.com' is therefore not allowed access.


如果后台用的PHP:

在被请求的Response header中加入

// 指定允许其他域名访问

header('Access-Control-Allow-Origin:*'); 

// 响应类型

header('Access-Control-Allow-Methods:POST');     

// 响应头设置

header('Access-Control-Allow-Headers:x-requested-with,content-type'); 


如果后台用的Java:

    添加如下设置允许跨域即可

response.setHeader("Access-Control-Allow-Origin", "*");

添加位置可以在下面三处任选一个。

1.可以在过滤器 filter 中的 dofilter() 方法设置。
2.可以在 servlet 的 get 或者 post 方法里面设置。
3.可以放在访问的 jsp 页面第一行。

这样就能轻松解决了!是不是美滋滋呀!





  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值