jsonp跨域简单实例

42 篇文章 0 订阅
15 篇文章 0 订阅

浏览器的同源策略,限制脚本程序只能和同协议,同域名,同端口的脚本进行交互,包括共享和传递变量,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.      %> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值