ajax,用苍白的话赞赏:很好。php
咱们能够使用ajax实现异步获取数据,减小服务器运算时间,大大地改善用户体验;咱们能够使用ajax实现小系统组合大系统;咱们还能够使用ajax实现前端的优化。(好一个排比)html
虽然ajax很好,但在使用起来也会有必定的限制,出于安全考虑,不容许跨域通讯。若是尝试从不一样的域请求数据,会出现安全错误。(下面例子1能够直观看出)前端
同源策略阻止从一个域上加载的脚本获取或操做另外一个域上的文档属性。也就是说,受到请求的 URL 的域必须与当前 Web 页面的域相同。这意味着浏览器隔离来自不一样源的内容,以防止它们之间的操做。这个浏览器策略很旧,从 Netscape Navigator 2.0 版本开始就存在。——摘自developerWorksweb
所谓同源是指,域名,协议,端口相同。ajax
本文讲解的是怎么利用ajax利用jsonp实现跨域请求,那么知道“同源策略”,就能够解决不少疑问:“为毛个人ajax加载不了数据!”“为毛浏览器控制台会对我如此漂亮的代码报错!”json
先上一个错误示范跨域
客户端代码:浏览器
<script> // 客户端使用getJSON方法请求另外一台机子上的脚本 $.getJSON("http://172.22.22.120/new/ajax.php",function(json){ alert(json.website); }); </script>
服务端PHP脚本代码:安全
<?php // ajax.php header('Content-type: application/json'); echo json_encode(array('website'=>'hcoding')); ?>
firefox下的错误提示:服务器
根据同源策略的概念,localhost和172.22.22.120是出于不一样的域名下的,因此跨域请求理所固然地被浏览器拒绝了。
JSONP(JSON with Padding)是资料格式 JSON 的一种“使用模式”,可让网页从别的网域要资料。另外一个解决这个问题的新方法是跨来源资源共享。因为同源策略,通常来讲位于 server1.example.com 的网页没法与不是 server1.example.com 的服务器沟通,而 HTML 的 <script> 元素是一个例外。利用 <script> 元素的这个开放策略,网页能够获得从其余来源动态产生的 JSON 资料,而这种使用模式就是所谓的 JSONP。用 JSONP 抓到的资料并非 JSON,而是任意的 JavaScript,用 JavaScript 直译器执行而不是用 JSON 解析器解析。——摘自维基百科
这话该怎么理解呢!我我的是这样认为的,用<script>跨域的请求数据,跨域的服务器返回一段【JavaScript代码】,是 的,你没看错,不是json格式数据,是JavaScript代码,这样,这段代码就由JavaScript 直译器执行。上例子更直观:
客户端代码:
<script> // 这是回调方法 function cb(data){ alert(data.website); } </script> <!--这是跨域请求的代码,切记,这段代码要在回调函数以后--> <script src="http://172.22.22.120/new/ajax_jsonp.php?callback=cb"></script>
服务端PHP脚本代码:
<?php $cb = htmlspecialchars($_GET['callback']); // 注意了,这里要作好过滤,防止xss攻击 echo $cb,'(',json_encode(array('website'=>'hcoding')),')'; // 返回客户端的数据为:cb({"name":"hcoding"}) 这是一段js代码 ?>
浏览器会发生什么事呢,我就不说了,固然是cb方法被调用啦:
因此,再说jsonp的概念,利用<script>不受同源策略的限制,跨域的服务器把要返回的json数据做为参数和回调函数一块儿返回客户端。
本文要讲ajax的跨域请求,前面说了那么多,下面固然要讲主题啦。
从 1.2 版本开始,jQuery 拥有对 JSONP 回调的本地支持。若是指定了 JSONP 回调,就能够加载位于另外一个域的 JSON 数据,回调的语法为:url?callback=?。jQuery 自动将 ? 替换为要调用的生成函数名。
客户端代码:
<script> // 客户端使用getJSON方法请求另外一台机子上的脚本 // 浏览器会生成一个随机的callback参数 $.getJSON("http://172.22.22.120/new/ajax_jsonp.php?callback=?",function(json){ alert(json.website); }); </script>
服务端PHP脚本代码:
<?php $cb = htmlspecialchars($_GET['callback']); // 注意了,这里要作好过滤,防止xss攻击 echo $cb,'(',json_encode(array('website'=>'hcoding')),')'; // 返回客户端的数据,这是一段js代码 ?>
$.getJSON简单易用,但就是不能指定回调函数。
客户端代码:
<script> $.ajax({ type : "GET", url : "http://172.22.22.120/new/ajax_jsonp.php", dataType : "jsonp", // 数据格式指定为jsonp jsonp: "callback", // 服务点经过这个键值获取回调方法 jsonpCallback:"cb", // 指定回调方法 success : function(json){ }, }); // 回调方法 function cb(data){ alert(data.website); } </script>
服务端PHP脚本代码和例子3的相同。
正所谓无规矩不成方圆,以安全为出发点,遵循同源策略是一个好品德。但咱们也有跨域请求的需求,jsonp就能知足咱们的需求。固然跨域请求还有不少的方法,不单止jsonp。
本文连接:http://www.hcoding.com/?p=238
原创文章,转载请注明:JC&hcoding.com