了解:ajax、json、jsonp、“跨域”的关系

要弄清楚以上ajax、json、jsonp概念的关系,我觉得弄清楚ajax是“干什么的”,“怎么实现的”,“有什么问题”,“如果解决存在的问题”等这几个问题,就自然明白了。

1)ajax是干什么的?

Ajax是最大的亮点是在不刷新页面的情况下,迅速的响应用户的一些请求行为,从而提升用户的体验。

2)怎么实现的?

Ajax是基于xmlHttpRequest(XHR)对象与server端进行通信,将一些数据传送给服务器端,服务器端再以一定的格式将结果数据返回给客户端处理。其中目前最流行的数据格式就是json格式。

在ajax请求的场景中,我们可以通过firefox的firebugger查看XHR,就可以找到该请求的一些信息了。

3)有什么问题?

由于xmlHttpRequest(XHR)对象是遵守浏览器同源策略的,因而只能与当前页面同源的server端进行交互,也就是会遇到“跨域问题”。

这里可以得出一个结论:目前只要是采用基于xmlHttpRequest(XHR)对象的ajax请求就会碰到“跨域问题”。

4)如何解决?

Ajax由于是基于xmlHttpRequest(XHR)对象的,有跨域问题,那对于跨域的请求ajax就行不通了,只能另找它法了。

JSONP就是其中一种方案。JSONP实际上是利用浏览器同源策略对<script>标签的引入不做限制这一缺口,实现跨域请求的。也就是说浏览器可以跨域引入其他域的script脚本,这样就可以通过js生成一个script标签,并让它的src指向不同域的链接对不同域的server端发起请求,server端进行处理后,返回一段script脚本,在客户端执行。

举一个自己试验过的例子,在任意一个页面中,写入类似如下的script标签和js函数:

这样后端返回类似test(data)的数据,在页面上执行,就完成了跨域请求。

结论:

从上面四点,就可以知道json是ajax请求的一种数据交换格式,jsonp与ajax是完全不同的两种请求方式,jsonp是用来解决ajax不能跨域的一种解决方案。

启发:

     1) 要实现跨域,基于XHR的ajax目前基本是行不通的。

2) 要实现跨域,只要找到既不刷新页面、又不被浏览器阻止与js交互的请求方式,基本上就找到了跨域请求的解决办法。

例如:script请求、image请求、flash请求等都是可以利用来做异步请求的。

a.      Jsonp就是script请求的典型代表之一,而且是我们平时用的最多的一种方式;

b.      image请求其实我们也已经用过很多了,比如我们经常用的打点功能,查看其源码,可以知道打点功能完全可以基于这种方式完成的;

c.      flash请求用的比较少,跨域的例子在我们的应用中暂时还没找到,不过通过flash自身本身就有跨域实现机制,而且与js交互也比较灵活,可以分析出实现跨域应该是没有问题。

亲身测试:TSP项目

这两天在项目中写的一个ajax jsonp的使用,出现了问题:可以成功获得请求结果,但没有执行success方法,直接执行了error方法提示错误——ajax jsonp之前并没有用过,对其的理解为跟普通的ajax请求差不多,没有深入了解;出现了这种错误,几经调试(检查后台的代码和js部分的属性设置)还是不行,让我感觉很是意外和不解。于是,决定仔细研究下ajax jsonp的使用,并将最后测试成功。

前台代码:

 $("#aa-btn").click(function () {
$.ajax({
type: "get",
async: false,
url: "http://localhost:2475/news/getNews.ashx?action=get&type=0",
dataType: "jsonp",
jsonp: "callbackparam", //传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(默认为:callback)
jsonpCallback: "success_jsonpCallback", //自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名
success: function (json) {
debugger;
alert(json);
},
error: function (e, a, d) {
debugger;
alert('fail');
}
});
});

后台服务代码:

 public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "application/json";
context.Response.ContentEncoding = System.Text.Encoding.UTF8;
string ReturnCode = string.Empty;
string callback = string.Empty;
string ErrorMsg = "参数错误";
ToJsonP tojsonp = new ToJsonP();
NewsBLL bll = new NewsBLL();
if (!string.IsNullOrEmpty(context.Request["callbackparam"]))
{
callback = context.Request["callbackparam"];//跨域-必有项。这个是跨域请求的回调,同前台Ajax的配置项jsonp同名(默认也是callback)。
}
string type = context.Request["type"];
ReturnCode = tojsonp.DataConvert(bll.GetNewsList(type));
//context.Response.Write(ReturnCode);
context.Response.Write(callback + "(" + ReturnCode + ")");
context.ApplicationInstance.CompleteRequest(); }

结果:正常进入success:functions(){}

jQuery的ajax jsonp跨域请求的更多相关文章

  1. jQuery的Ajax的跨域请求

    今天碰到一个Ajax跨域请求的问题,我把源码down下来,然后在服务器端写了一个http请求的代理(因为服务器端是不存在跨域问题的),说白了就是用BufferedReader写了个IO流,然后读取到目 ...

  2. Ajax jsonp 跨域请求实例

    跨域请求 JSONP的缺点则是:它只支持GET请求而不支持POST等其它类型的HTTP请求:它只支持跨域HTTP请求这种情况,不能解决不同域的两个页面之间如何进行JavaScript调用的问题. $. ...

  3. ajax jsonp 跨域请求

    $.ajax({ type:"get", url: "http://localhost/test/a.php", dataType: "jsonp&q ...

  4. JSONP 跨域请求 - 获取JSON数据

    如何用原生方式使用JSONP? 下边这一DEMO实际上是JSONP的简单表现形式,在客户端声明回调函数之后,客户端通过script标签向服务器跨域请求数据,然后服务端返回相应的数据并动态执行回调函数. ...

  5. jQuery ajax的jsonp跨域请求

    一直在听“跨域跨域”,但是什么是跨域呢?今天做了一些了解.(利用jQuery的jsonp) jQuery使用JSONP跨域 JSONP跨域是利用script脚本允许引用不同域下的js实现的,将回调方法 ...

  6. 利用jquery的ajax实现跨域,内部其实是jsonp协议了,不是XHRhttp协议

    一.同源策略 要理解跨域,先要了解一下“同源策略”.所谓同源是指,域名,协议,端口相同.所谓“同源策略“,简单的说就是基于安全考虑,当前域不能访问其他域的东西. 一些常见的是否同源示例可参照下表: 在 ...

  7. .net学习之母版页执行顺序、jsonp跨域请求原理、IsPostBack原理、服务器端控件按钮Button点击时的过程、缓存、IHttpModule 过滤器

    1.WebForm使用母版页后执行的顺序是先执行子页面中的Page_Load,再执行母版页中的Page_Load,请求是先生成母版页的控件树,然后将子页面生成的控件树填充到母版页中,最后输出 2.We ...

  8. jQuery之ajax的跨域获取数据

    如果获取的数据文件存放在远程服务器上(域名不同,也就是跨域获取数据),则需要使用jsonp类型.使用这种类型的话,会创建一个查询字符串参数 callback=? ,这个参数会加在请求的URL后面.服务 ...

  9. JSONP跨域请求数据报错 “Unexpected token :”的解决办法

    原文  http://www.cnphp6.com/archives/65409 Jquery使用ajax方法实现jsonp跨域请求数据的时候报错 “Uncaught SyntaxError: Une ...

随机推荐

  1. ZigBee心电传输(三)

    这段时间因为另外一个项目需要,我搞Zed板去了.现在接着上一步的工作吧,继续把心电做完.这里想要测试一下把心电波形数据传输出来,然后用协调器接收,并从串口显示出来.之后再用ZigBee转蓝牙,从而可以 ...

  2. Android应用调试经常使用知识

    1.Android应用启动过程调试 1).进入设置-->辅助功能-->开发人员选项:假设没有打开开发人员模式.在拨号里面输入*#*#6961#*#*: 2).找到选择调试应用,打开选择你要 ...

  3. 设计模式14---设计模式之命令模式(Command)(行为型)

    1.场景模拟 请用软件模拟开机过程 按下启动按钮 然后电源供电 主板开始加电自检 BIOS依次寻找其他设备的BIOS并且让他们初始化自检 开始检测CPU,内存,光盘,硬盘,光驱,串口,并口,软驱即插即 ...

  4. android 开发工具(转)

    一.Android SDK (Android SDK主安装包,包含SDK Manager.AVD Manager.工具包tools,释放后的根文件夹为android-sdk-windows): rev ...

  5. arcgis server "System.Web.Services.Protocols.SoapException: Error processing server request".

    在 Arcgis Server 10中创建第一个程序,运行的时候就报错:System.Web.Services.Protocols.SoapException: Error processing se ...

  6. Linux最小化安装后配置网络

    vi /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth0HWADDR=00:0C:29:DD:AD:B9TYPE=EthernetUUID=d7 ...

  7. jdbc 获取connection 对象的三种方式

    获取数据库连接方法一:驱动实现类 //创建mysql的Driver对象 Driver driver=new com.mysql.jdbc.Driver(); //jdbc url 定位一个数据库: S ...

  8. BZOJ 1588: Treap 模板

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 12171  Solved: 4352 Description ...

  9. spring的CXF远程服务

    http://www.tuicool.com/articles/Rb2uUn      //远程调用  spring的cxf,亲自整合成功

  10. php 文件操作中几种方法整理

    1.获取文件夹下所有文件个数 echo ShuLiang("../0503lianxi"); function ShuLiang($filename) { if(is_dir($f ...