简单的jsonp实现跨域原理

什么原因使jsonp诞生? 

       传说,浏览器有一个很重要的安全限制,叫做"同源策略"。同源是指,域名,协议,端口相同。举个例子,用一个浏览器分别打开了百度和谷歌页面,百度页面在执行脚本的时候就会检查这个脚本是否属于百度页面,只有和百度同源的脚本才会执行,这就是同源策略。(相当于给脚本按了一个大门,只允许在大门内部活动)

       但是我们在工作中有时又会需要和不同域名的网站进行交流,由于同源策略的限制,使操作变得有些困难。jsonp是目前比较主流的跨域方式。什么是jsonp呢?我们来了解一下。

 

 jsonp和json有什么关系吗?

       jsonp(JSON with Padding)和json很像,但却完全不是一回事儿。json和xml有些类似,是用于存储和表达数据的一种方式,也是javascript对象的表示。而jsonp是获取、传递数据的一种方式。打个比方,在早前的飞鸽传书,大家都知道吧?json相当于传递的书信,而jsonp是携带书信的飞鸽。这么一说,相信大家就都明白了!^_^

 

 jsonp的原理是什么?

       整体来说,jsonp实现跨域的原理是跨域的服务端把客户端所需要的数据放进客户端本地的一个js方法里,进行调用,客户端在本地的js对返回的数据进行处理。这样就实现了不同域名下的两个站点间的交流。

       由于

 

本地回调函数

function Hello(data){

     alert(data.result);

}

 

 

跨域服务端:

protected void Page_Load(object sender, EventArgs e)
{

     string callback=Request.QueryString["callback"];//获取客户端回调函数名,值为"Hello"

     Response.Write(callback+"({result:1})");  //调用客户端指定函数,并把数据传进去

 }

 

转载于:https://www.cnblogs.com/xinyueBlog/p/6179159.html

你可能感兴趣的:(json,javascript,ViewUI)