node.js与HTML5离线缓存
最近正学到HTML5的离线缓存,却看到需要配置服务器。一下子就懵了,毕竟服务器的有关配置一般是很复杂的,而node.js的服务器是自己的代码生成的,这下要怎么配置?在网上搜索了很久,都没用关于node.js与HTML5离线缓存的,但是apache之类的却一大堆。在看完网易云课堂的一个php教程之后,开始理解了HTML5的离线缓存原理,并成功搭配node.js实现了。
首先简要讲一下HTML5离线缓存的原理。
浏览器向服务端发出请求,请求获取一份MIME类型为 text/cache-manifest 的文件,该文件本身就是静态文件,这点很重要,并且该文件记录了浏览器要缓存哪些文件。
这时候第一个问题来了,manifest文件内容格式怎么写?
答:举个简单的例子,该例子列出了浏览器要缓存的文件。
CACHE MANIFEST
# CACHE MANIFEST 是必须的开头
# CACHE : 下罗列了要缓存的文件名
CACHE:
1.jpg
解决了第一个问题第二个问题来了,html5是怎么去请求这份文件的?
答:
在你的html代码里的 html标签中这样写: <html manifest="test.manifest" >;这样浏览器就会向请求其它资源一样向服务器请求这个名为 test.manifest文件了。
举个简单的例子加深理解:通过 http://localhost/index.html 访问服务器根目录下的index.html文件,html代码如下
<!DOCTYPE html>
<html manifest="test.manifest">
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<img src="1.jpg" />
</body>
</html>
test.manifest文件内容如上面第一问题中的例子;
当浏览器渲染到 <html manifest="test.manifest">时,浏览器发出一个请求,请求获取test.manifest文件,当浏览器加载了test.manifest文件后浏览器就知道1.jpg是要缓存的文件,所以,当1.jpg第一次被加载下来后,就被缓存到本地了。当第二访问http://localhost/index.html 时,浏览器直接到缓存去取1.jpg了。即使断网了,也能够通过http://localhost/index.html访问到刚刚的页面。
到了现在,我们还是没讲到node.js。已知apache等服务器要支持离线缓存的话需要配置服务器,如果是node.js,那该怎么办?
答:我们先来了解一下,apache等服务器究竟是要配置什么鬼东西。上面已经说了manifest文件本身就是一个静态文件,获取manifest文件跟获取jpg文件其实就是一回事,但是apache等服务器不是所有的文件格式都支持,换句话说,你浏览器请求jpg文件是被允许的,但是,你请求manifest文件是不在允许范围内的,所以,配置服务器指定的就是在服务器允许的文件类型中加多一条:manifest 类型。
而对于node.js说,不论是jpg,png,manifest.......,它们都是文件而已,node.js对它们一视同仁,唯一不同的地方就是它们的MIME类型。
所以,对于HTML5的离线缓存功能来说,node.js需要的配置就是在写静态文件服务器时,增加对manifest MIME类型支持。
如果你用express的配置静态文件服务器的话,express已经帮你增加了manifest文件的支持了。一个字:爽!
node.js与HTML5离线缓存的更多相关文章
- HTML5离线缓存(Application Cache)
HTML5离线缓存又名Application Cache,是从浏览器的缓存中分出来的一块缓存区,要想在这个缓存中保存数据,可以使用一个描述文件(manifest file),列出要下载和缓存的资源. ...
- HTML5 离线缓存管理库
一.HTML5离线缓存技术 支持离线缓存是HTML5中的一个重点,离线缓存就是让用户即使在断网的情况下依然可以正常的运行应用.传统的本地存储数据的方式有 localstorage,sessionsto ...
- HTML5离线缓存问题
HTML5离线缓存问题 1.应用程序缓存 什么是应用程序缓存(Application Cache)? HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问. ...
- html5离线缓存使用
html5 离线缓存使用以及注意事项 1.index.html中加入离线缓存的声明文件 如:<!DOCTYPE html><html manifest="test.appc ...
- HTML5离线缓存攻击测试
本实验采用局域网模拟,通过修改本地HOSTS文件来模拟域名以及DNS欺骗.合法网站使用Linux CentOS7的apache服务器搭建,IP为192.168.1.113,HOSTS文件中加入192. ...
- HTML5 离线缓存Appcache
创建一个和html同名的manifest文件,比如页面为index.html,那么可以建一个index.manifest的文件,然后给index.html的html标签添加如下属性即可: <ht ...
- HTML5离线缓存
参考文档:http://www.w3cschool.cc/html/html5-app-cache.html HTML5 应用程序缓存 又称离线缓存 ,即使断线了,刷新后也还是缓存了原来的页面,不会4 ...
- 使用 jQuery Mobile 与 HTML5 开发 Web App —— HTML5 离线缓存
本文要介绍的,是 HTML5 离线网络应用程序的特性,离线网络应用程序在 W3C 中的实际名称是 "Offline Web applications" ,也称离线缓存.当用户打开浏 ...
- HTML5 离线缓存详解(转)
离线缓存是html5新特性之一,简单理解就是第一次加载后将数据缓存,在没有清除缓存前提下,下一次没有网络也可以加载,用在静态数据的网页或游戏比较好用.当然,Html5新的特性都不是所有浏览器都能支持的 ...
随机推荐
- SVN报错 Not Found In Revision 不支持空目录
如果你要初始化上传的SVN目录为空,有可能会报这个错误 解决方法:在SVN下新建一个目录即可
- jQuery的each内部的break,continue
// break, continue在each等迭代器里都不可用 // return false = break // return true = continue function isClicke ...
- bzoj4890[Tjoi2017]城市(树的半径)
4890: [Tjoi2017]城市 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 149 Solved: 91[Submit][Status][D ...
- P3343 [ZJOI2015]地震后的幻想乡
传送门 给积分大佬跪了 再给状压大佬也跪了 //minamoto #include<bits/stdc++.h> #define rint register int #define ll ...
- [Swift通天遁地]一、超级工具-(11)使用EZLoadingActivity制作Loading加载等待动画
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- Head Html Css 第二版笔记
一. 引用 <blockquote>ago aog aogag </blockquote> 则是引用一大段文字并独立显示 二. <a> 创建目的地 <h2&g ...
- C# 堆VS栈 值类型VS引用类型
最近博客园上连续出现了几篇关于堆VS栈 值类型VS引用类型的文章. 一个是关于C# 堆VS栈的,深入浅出,动图清晰明了,链接如下 C#堆栈对比(Part One) C#堆栈对比(Part Two) C ...
- [ TJOI 2010 ] 打扫房间
\(\\\) Description 给出一个\(N\times M\) 的网格,一些格子是污点,求是否能用多个封闭的环路覆盖所有不是污点的格点. 封闭的环路覆盖的含义是,每条路径都必须是一个环,且每 ...
- [ NOI 2002 ] Robot
\(\\\) Description \(\\\) Solution 垃圾语文题毁我青春 这题其实就是重定义了俩函数.... 首先 \(\varphi(1)=0\) . 然后 \(2\) 在计算 \( ...
- DatePickerDialog和TimePickerDialog(基于对话框显示时间和日期)
public class MainActivity extends Activity implements android.view.View.OnClickListener{ private But ...