ASP.NET MVC实战:jQuery调用Ajax缓存

简介:

尽管jQuery在浏览器ajax调用的时候对缓存提供了很好的支持,还是有必要了解一下如何高效地使用http协议。

  首先要做的事情是在服务器端支持HTTP GET,定义不同的URL输出不同的数据(MVC里对应的就是action)。如果要使用同一个地址获取不同的数据,那就不对了,一个HTTP POST也不行因为POST不能被缓存。许多开发人员使用POST主要有2个原因:明确了数据不能被缓存,或者是避免JSON攻击(JSON返回数组的时候可以被入侵)。

  缓存解释

  jQuery全局对象里的ajax方法提供了一些options来支持缓存和Conditional GETs功能。

 $.ajax({

  ifModified: [true|false],

  cache: [true|false],

  });

  ifModified选项定义的是在ajax调用的时候是否支持Conditional GETs功能。jQuery会自动帮我们处理服务器端返回的名为Last-Modified的header值,然后在随后的请求里的header里发送If-Modified-Since。这需要我们的MVC Controller要实现Conditional GETs功能才能用。Conditional GETs功能在http缓存上下文中用于重新验证缓存中过期的条目。如果jQuery认为一个条目已经过期了,它首先会请求服务器使用Conditional GETs功能重新验证该条目,如果服务器返回状态码304(Not modified),jQuery会重新使用缓存里的该项目,这样的话,我们可以节约很多流量去下载页面内容。

  cache选项基本上是覆盖服务器端返回的http header里的所有关于缓存的设置,如果设置cache选项为false的话,jQuery会在请求的URL后面附件一个时间戳,以便区分之前的URL地址,这样没错请求的内容都是最新的,也就是说浏览器每次接收的都是新地址,自然返回的都是最新数据。

  让我们来看几个场景:

  服务器端响应里设置No-Cache

  服务器端为王,如果服务器端明确定义了response响应不能被缓存的话,jQuery也无能为力。ajax里的cache选项将被忽略。

  JS代码:

$('#nocache').click(function () {

  $.ajax({

  url: '/Home/NoCache',

  ifModified: false,

  cache: true,

  success: function (data, status, xhr) {

  $('#content').html(data.count);

  }

  });

  });


 

  C#代码:

public ActionResult NoCache()

  {

  // 禁用缓存

  Response.Cache.SetCacheability(HttpCacheability.NoCache);

  return Json(new { count = Count++ }, JsonRequestBehavior.AllowGet);

  }


 

  服务器端响应里设置过期时间

  服务器端设置过期时间用于缓存数据,该条目在客户端将依据过期时间被缓存。

  JS代码:

$('#expires').click(function () {

  $.ajax({

  url: '/Home/Expires',

  ifModified: false,

  cache: true,

  success: function (data, status, xhr) {

  $('#content').html(data.count);

  }

  });

  });


 

  C#代码:

public ActionResult Expires()

  {

  Response.Cache.SetExpires(DateTime.Now.AddSeconds(5));

  return Json(new { count = Count++ }, JsonRequestBehavior.AllowGet);

  }


 

  客户端从来不缓存数据

  客户端决定每次都要最新的数据(不能使用缓存),也就是说ajax里的cache选项设置为false,不管服务器端如何定义,jQuery每次请求的URL地址都是唯一不同的,目的是每次都获取最新的内容。

  JS代码:

$('#expires_nocache').click(function () {

  $.ajax({

  url: '/Home/Expires',

  ifModified: false,

  cache: false, // 这里是关键

  success: function (data, status, xhr) {

  $('#content').html(data.count);

  }

  });

  });


 

  C#代码:

public ActionResult Expires()

  {

  // 不管服务器端怎么设置都没用

  Response.Cache.SetExpires(DateTime.Now.AddSeconds(5));

  return Json(new { count = Count++ }, JsonRequestBehavior.AllowGet);

  }

  服务器端和客户端使用Conditional Gets功能验证缓存数据

  客户端将条目放在缓存里,在过期之后重新验证。服务器端必须实现Conditional GET功能(使用ETags或者last modified的header)。

  JS代码:

$('#expires_conditional').click(function () {

  $.ajax({

  url: '/Home/ExpiresWithConditional',

  ifModified: true, // 这里是关键

  cache: true,

  success: function (data, status, xhr) {

  $('#content').html(data.count);

  }

  });

  });

  C#代码:

public ActionResult ExpiresWithConditional()

  {

  if (Request.Headers["If-Modified-Since"] != null && Count % 2 == 0)

  {

  return new HttpStatusCodeResult((int)HttpStatusCode.NotModified);

  }

  Response.Cache.SetExpires(DateTime.Now.AddSeconds(5));

  Response.Cache.SetLastModified(DateTime.Now);

  return Json(new { count = Count++ }, JsonRequestBehavior.AllowGet);

  }


 

  上述MVC action中的代码只是一个例子(非真实代码),在真实的实现中,服务器端应该能否知道数据自从上次响应以后是否被修改过。

  总结

  详细通过这4个场景,大家应该了解了ajax请求的缓存技术了吧,我就不做总结了。










本文转自 wws5201985 51CTO博客,原文链接:http://blog.51cto.com/wws5201985/781953,如需转载请自行联系原作者
目录
相关文章
N..
|
7月前
|
XML JSON 前端开发
jQuery实现Ajax
jQuery实现Ajax
N..
71 1
|
7月前
|
XML 前端开发 JavaScript
jQuery中ajax如何使用
jQuery中ajax如何使用
91 0
|
7月前
|
开发框架 JSON JavaScript
ASP.NET Core3.1实战教程---基于Jquery单文件上传
ASP.NET Core3.1实战教程---基于Jquery单文件上传
86 0
|
6月前
|
前端开发 JavaScript
杨校老师课堂之基于Servlet整合JQuery中的Ajax进行表单提交[基于IDEA]
杨校老师课堂之基于Servlet整合JQuery中的Ajax进行表单提交[基于IDEA]
52 0
杨校老师课堂之基于Servlet整合JQuery中的Ajax进行表单提交[基于IDEA]
|
4月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
56 0
|
4月前
|
XML JSON 前端开发
AJAX是什么?原生语法格式?jQuery提供分装好的AJAX有什么区别?
AJAX是什么?原生语法格式?jQuery提供分装好的AJAX有什么区别?
35 0
|
4月前
|
JavaScript 前端开发
Ajax的使用(jquery的下载)
这篇文章是关于Ajax学习笔记的分享,包括JQuery的下载方式、Ajax的主要参数说明,以及如何在网页中使用Ajax进行异步请求的示例代码。
|
6月前
|
JavaScript 前端开发 安全
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
安全开发-JS应用&原生开发&JQuery库&Ajax技术&加密编码库&断点调试&逆向分析&元素属性操作
|
7月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
212 0
|
7月前
|
前端开发 JavaScript PHP
【PHP开发专栏】jQuery与PHP实现Ajax通信
【4月更文挑战第30天】本文介绍了使用jQuery和PHP实现Ajax通信的步骤。首先,讲解了Ajax的基础和jQuery简化Ajax操作的概念。接着,展示了如何使用jQuery的`$.get()`、`$.post()`和`$.ajax()`方法发送GET和POST请求,以及如何控制请求细节。在PHP端,讨论了接收和响应Ajax请求的方法,包括处理数据、设置响应类型和错误处理。结合jQuery与PHP,开发者能实现高效、无缝的异步数据传输,提升Web应用的用户体验。
134 1
下一篇
DataWorks