1. Ajax不能跨域请求的原因
同源策略(Same Origin Policy),是一种约定,该约定阻止当前脚本获取或者操作另一个域下的内容。所有支持Javascript的浏览器都支持同源策略,也就是说浏览器可以隔离来自不同源的内容,阻止跨域请求的发生。
通俗的说法就是,A服务器的a端口下执行的普通ajax程序,不能访问B服务器或A服务器的其他端口,是一种隔离策略.但对于标签下的'src'属性无效,因为这个属性就是请求其他服务器的,所以可以利用<script>的src属性请求域外服务器:
<script type="text/javascript" src="www.baidu.com/test.js"></script>
ajax在跨域请求时需要借助jsonp格式
2.解决方法
(1)CORS
在被请求的脚本中使用header()函数设置http响应,从而使得跨域请求能够发生:
header(“Access-Control-Allow-Origin:*”);
这一方法称为CORS(Cross-Origin Resource Sharing),是w3c的工作草案。
(2) 使用Jsonp (Json with padding)
jsonp的原理是通过script标签的src属性来请求不同源的脚本。
步骤:
2)定义回调函数
4)在回调函数中处理返回数据
发送跨域请求的html页面:
1 <script type="text/javascript"> 2 function crossDomain() 3 { 4 //1.创建script标签,设置src属性 5 var script = document.createElement('script'); 6 在script标签的src属性中发送跨域请求 7 传递get参数 --> 回调函数的名字 8 script.src = 'http://www.another.com/index.PHP?name=Jonas&callback=say'; 9 document.getElementsByTagName('head')[0].appendChild(script); 10 } 11 12 2.定义回调函数 13 function say(data) 14 { 15 4.处理返回数据 16 console.log(data); 17 } 18 </script>
1 <?PHP 2 3.执行回调函数,将返回数据以参数的形式传给回调函数
3 $data = json_encode(array('msg' => 'hello world')); 4 echo $_GET['callback'] . "({$data})"; 5 ?>
同源策略
"Permission denied to call method XMLHttpRequest.open"为什么会出这样的错误呢?这是因为所有支持Javascript的浏览器都会使用同源策略这个安全策略。看看百度的解释:
同源策略,它是由Netscape提出的一个著名的安全策略。现在所有支持JavaScript 的浏览器都会使用这个策略。所谓同源是指,域名,协议,端口相同。当一个浏览器的两个tab页中分别打开来 百度和谷歌的页面当一个百度浏览器执行一个脚本的时候会检查这个脚本是属于哪个页面的,即检查是否同源,只有和百度同源的脚本才会被执行。
这就是引起为何取不到数据的原因了,那如何才能解决跨域的问题呢?没错,我们现在可以进入正题,来了解下什么是JSONP了。
JSON和JSONP
JSONP和JSON好像啊,他们之间有什么联系吗?
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。对于JSON大家应该是很了解了吧,不是很清楚的朋友可以去json.org上了解下,简单易懂。
JSONP是JSON with Padding的略称。它是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问(这仅仅是JSONP简单的实现形式)。--来源百度
JSONP就像是JSON+Padding一样(Padding这里我们理解为填充), 我们先看下面的小例子然后再详细介绍。
跨域的简单原理
光看定义还不是很明白,那首先我们先来手动做个简单易懂的小测试。新建一个asp.net的web程序,添加sample.html网页和一个test.js文件,代码如下:
sample.html的代码:
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 html xmlns="http://www.w3.org/1999/xhtml" 3 head4 title>test</5 ="test.js"6 7 body8 9 html>@H_403_311@