跨域
浏览器有同源策略,禁止ajax从一个域名请求另外一个域名上的数据,如果从一个域名请求另外一个域名上的数据,就是跨域。
那什么是同源策略,所谓同源,就是指域名、协议、端口都相同。比如说:一个浏览器打开百度的网站,然后在控制台请求腾讯的网页,浏览器会报一个不是同源的异常。如下图:
![](https://img.haomeiwen.com/i12653063/c1704f2eb0618f4e.png)
如何进行跨域请求呢?
- 使用php做代理请求
Php是服务端语言,是没有跨域限制的。再直白一点,就是javascript通过ajax将请求交给php做,php请求到的数据再交给javascript处理。
例
![](https://img.haomeiwen.com/i12653063/3e5e45fa7cd61fbb.png)
- 在服务端设置响应头,允许跨域请求
如果有可能,可以在服务端被请求页面添加响应头,
header(”Access-Control-Allow-Origin:”);号表示允许所有域名访问,也可以指定允许的域名。例如:某人有两个域名,一个域名中想使用另一个域名中数据,可以这样操作。
![](https://img.haomeiwen.com/i12653063/dd03e51a24dcf01a.png)
header('Access-Control-Allow-Origin:*');
- 通过jsonp来实现
实际上就是利用script标签的src属性没有跨域限制的漏洞来完成请求。例如:
![](https://img.haomeiwen.com/i12653063/b5f0b27f9c960348.png)
<script>
var script=document.createElement('script');
script.setAttribute('src',"http://www.php.com/test.php?callback=response");
$('head').append(script);
function response(res){
$('#result').text(res);
}
<script>
fun=fun=_GET['callback'];
echo "$fun(".time().")";
网友评论