日期:2014-05-16  浏览次数:20386 次

jsonp跨域简单实例

jsonp跨域简单实例

    博客分类:
  • javascript
jsonp

浏览器的同源策略,限制脚本程序只能和同协议,同域名,同端口的脚本进行交互,包括共享和传递变量,cookie的传递。尽管浏览器不允许页面脚本跨域读 取数据,但是允许html引用跨域的资源,比如脚本程序,css,图片,等等,因为script,iframe的src是不存在跨域的。

Java代码 ?收藏代码
  1. $.get( "http://www.b.com:8080/domain2/index.jsp" ,??
  2. {},?function(data){??
  3. alert('?error:' +data)??
  4. },?"html" );??



比如上面的请求,因为是跨域读取数据,所以,无法获取想要的数据


jsonp是非官方协议,它是在服务端生成script tags返回到客户端,在客户端通过javscript callback形式实现跨域访

问。

jsonp原理是客户端定义一个callback,然后把callback名字传送至服务端,服务端生成json数据,然后以javascript

的方式,生成一个以callback名字的function的javascript函数执行形式,将json数据以入参方式放到function中,就

生成了一个js的函数执行语法的文档,传到客户端。客户端浏览器解析script,执行服务端返回的javascript片段,返

回的数据作为参数,传入到客户端定义的callback中动态执行。

实例

Java代码 ?收藏代码
  1. //www.a.com:8080/domain1/index.jsp ??
  2. ??
  3. <script?type="text/javascript" >??????
  4. ????????function?sayHello(result){???????
  5. ???????????alert(result());???????
  6. ????????}???????
  7. ????</script>????
  8. ????<script?type="text/javascript" src="http: //www.b.com:8080/domain2/index.jsp? ??
  9. ??
  10. callback=sayHello"></script>??
  11. ??
  12. ??
  13. //www.b.com:8080/domain2/index.jsp ??
  14. ??
  15. ?<%??
  16. ????????String?script="function?show(){?return?'hello';}" ;??
  17. ????????//String?script="{name:'yuyong'}"; ??
  18. ????????String?callback=request.getParameter("callback" );??
  19. ????????out.println(callback+"(" +script+ ")" );??
  20. ?????%>?