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代码如下

 1 <!DOCTYPE html>
 2 <html manifest="test.manifest">
 3 <head>
 4     <meta charset="utf-8">
 5     <title></title>
 6 </head>
 7 <body>
 8    <img src="1.jpg" />
 9 </body>
10 </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文件的支持了。一个字:爽!

原文地址:https://www.cnblogs.com/zhaowy/p/9561344.html

时间: 2024-08-29 07:51:35

node.js与HTML5离线缓存的相关文章

HTML5 离线缓存管理库

一.HTML5离线缓存技术 支持离线缓存是HTML5中的一个重点,离线缓存就是让用户即使在断网的情况下依然可以正常的运行应用.传统的本地存储数据的方式有 localstorage,sessionstorage和cookie.但是这些传统的方式有着致命的弊端.首先这些传统的存储方式的最大使用空间有 限,最多不超过5M;其次它们处理大规模的结构化数据的能力有限.鉴于传统方式的局限性,HTML5提出了三种新的离线缓存解决方案:Web SQL,indexedDB和File System. 其中Web S

HTML5离线缓存(Application Cache)

HTML5离线缓存又名Application Cache,是从浏览器的缓存中分出来的一块缓存区,要想在这个缓存中保存数据,可以使用一个描述文件(manifest file),列出要下载和缓存的资源. Manifest 文件 manifest 文件是简单的文本文件,它告知浏览器被缓存的内容(以及不缓存的内容). manifest 文件可分为三个部分: CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存 NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓

html5离线缓存使用

html5 离线缓存使用以及注意事项 1.index.html中加入离线缓存的声明文件 如:<!DOCTYPE html><html manifest="test.appcache"> test.appcache 与 index.html在相同路径下. 2.服务器端加入MIME TYPE声明:tomcat如下 web.xml中加入<mime-mapping> <extension>manifest</extension> &l

HTML5离线缓存攻击测试

本实验采用局域网模拟,通过修改本地HOSTS文件来模拟域名以及DNS欺骗.合法网站使用Linux CentOS7的apache服务器搭建,IP为192.168.1.113,HOSTS文件中加入192.168.1.113 www.cache-test.com来模拟域名.正常访问页面如下图所示,在离线时也能够正常刷新出来. 攻击者由安装有XAMPP服务器的桥接虚拟机表示,IP为192.168.1.154.攻击者可以访问本目录的demo_html.appcache获得缓存文件,在同名文件加入自己的恶意

HTML5离线缓存

参考文档:http://www.w3cschool.cc/html/html5-app-cache.html HTML5 应用程序缓存 又称离线缓存 ,即使断线了,刷新后也还是缓存了原来的页面,不会404了 首先,请在文档的<html> 标签中包含 manifest 属性: <!DOCTYPE HTML> <html manifest="page.appcache"> <!--这里的page.appcache是一个文件,自己手动生成-->

HTML5离线缓存问题

1.应用程序缓存 什么是应用程序缓存(Application Cache)? HTML5 引入了应用程序缓存,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问.应用程序缓存为应用带来三个优势: 离线浏览 - 用户可在应用离线时使用它们 速度 - 已缓存资源加载得更快 减少服务器负载 - 浏览器将只从服务器下载更新过或更改过的资源. 主浏览器都支持,IE8.IE9除外 注意事项 MineType 文件需要配置正确的 MIME-type,即 "text/cache-manifest&

使用 jQuery Mobile 与 HTML5 开发 Web App —— HTML5 离线缓存

本文要介绍的,是 HTML5 离线网络应用程序的特性,离线网络应用程序在 W3C 中的实际名称是 "Offline Web applications" ,也称离线缓存.当用户打开浏览器时,浏览器会将一个列表中指定的资源都下载并储存在本地.下次当用户再访问这个网络程序时,浏览器会自动引用本地缓存中相应的文件,而不会再从网络下载这些资源.不管离线网络应用程序是否专为 Web Apps 而设,但这对于 Web Apps 来说无疑是个非常实用的特性,它使到 Web Apps 相对于原生 App

HTML5 离线缓存详解(转)

离线缓存是html5新特性之一,简单理解就是第一次加载后将数据缓存,在没有清除缓存前提下,下一次没有网络也可以加载,用在静态数据的网页或游戏比较好用.当然,Html5新的特性都不是所有浏览器都能支持的,离线缓存也一样.反正IE9(包括)及IE9以下的浏览器目前是不支持的.如果用在移动端,应该都能支持.检测是否支持离线缓存也是比较简单的. if(window.applicationCache){ alert("支持离线缓存"); } else{ alert("不支持离线缓存&q

基于MySQL + Node.js + Leaflet的离线地图展示,支持百度、谷歌、高德、腾讯地图

1. 基本说明 本项目实现了离线展示百度.谷歌.高德.腾讯地图.主要功能如下: 实现了地图瓦片图下载.存储.目前支持存储至MySQL Node.js服务调用MySQL中的瓦片图 Leaflet展示地图 展示效果如下: 2. 地图瓦片下载工具及配置 工具下载链接: http://pan.baidu.com/s/1qYoHj4K 密码: ehgh 工具使用方法: 数据库配置 打开工具目录中的 MapDownloader.exe.config 文件.根据实际情况填写如图中的配置信息. 地图瓦片图下载