瀏覽器緩存 cache-control etag

// node.js 示例代碼
const http = require('http');
const fs = require('fs');
const url = require('url');
const md5 = require('md5');
const port = process.argv[2]; // 獲取端口號(hào)

if (!port) {
  console.log('請(qǐng)指定端口號(hào)~~~');
  process.exit(1);
}

const server = http.createServer((request, response) => {
      const path = request.url;
      const parsedUrl = url.parse(path, true);
      const query = path.indexOf('?') >= 0 ? path.substring(path.indexOf('?')) : '';
      const pathNoQuery = parsedUrl.pathname; // 不包含查詢
      const queryObject = parsedUrl.query; // 查詢參數(shù)
      const method = request.method; // 請(qǐng)求方法

      switch (pathNoQuery) {
        case '/':
          let htmlStr = fs.readFileSync('./index.html', 'utf8');
          response.setHeader('Content-type', 'text/html; charset=utf-8');
          response.write(htmlStr);
          break;
        case '/index.html':
          let htmlStr2 = fs.readFileSync('./index.html', 'utf8');
          response.setHeader('Content-type', 'text/html; charset=utf-8');
          response.write(htmlStr2);
          break;
        case '/default.css':
          let cssStr = fs.readFileSync('./css/default.css', 'utf8');
          response.setHeader('Content-type', 'text/css; charset=utf-8');
          response.write(cssStr);
          break;
        case '/main.js':
          let jsStr = fs.readFileSync('./js/main.js', 'utf8');
          response.setHeader('Content-type', 'text/javascript; charset=utf-8');
          response.write(jsStr);
          break;
        default:
          response.statusCode = 404;
          break;
      }

      response.end();
});

server.listen(port);
console.log('監(jiān)聽 ' + port + ' 成功\n請(qǐng)打開 http://localhost:' + port);

cache-control

設(shè)置靜態(tài)文件過(guò)期時(shí)間
86400*365 = 31536000 一年的秒數(shù)

// 表示30s以內(nèi)不要再請(qǐng)求我霹陡,用緩存數(shù)據(jù)印衔。
response.setHeader('Cache-control', 'max-age=31536000');

一般在response header中設(shè)置靴跛,比如在下面的main.js添加

case '/main.js':
  let jsStr = fs.readFileSync('./js/main.js', 'utf8');
  response.setHeader('Content-type', 'text/javascript; charset=utf-8');
  response.setHeader('Cache-control', 'max-age=31536000'); // 注意這一行
  response.write(jsStr);
  break;

cache-control

main.js大小共1.1M,
第一次請(qǐng)求的時(shí)間為8.60s;
第二次請(qǐng)求時(shí)間為0s, 讀取from memory cache,注意此時(shí)狀態(tài)碼是 200,不是304巨柒。
由于沒有給default.css加cache-control,所以任然會(huì)向服務(wù)器發(fā)起請(qǐng)求,耗時(shí)600多毫秒柠衍。

Expires

// 跟cache-control的區(qū)別是cache-control定義的是失效時(shí)長(zhǎng)洋满,expires定義的是失效時(shí)間點(diǎn)
response.setHeader('Expires', 'Thu, 06 Sep 2018 12:52:52 GMT');

eTag

md5是一種文件摘要算法。etag值一般為文件對(duì)應(yīng)的md5值珍坊。
一般客戶端請(qǐng)求一個(gè)文件后牺勾,設(shè)置response header

const md5 = require('md5'); // 頭部引入

let cssStr = fs.readFileSync('./css/default.css', 'utf8');
// response.setHeader('Cache-control', 'max-age=86400');
const fileMd5 = md5(cssStr);

response.setHeader('eTag', fileMd5); // 響應(yīng)頭設(shè)置ETag屬性

如下圖所示,第一次請(qǐng)求default.css時(shí)阵漏,響應(yīng)頭中有ETag屬性驻民。


第一次請(qǐng)求時(shí)

比對(duì)文件MD5的值,一樣則返回304

let cssStr = fs.readFileSync('./css/default.css', 'utf8');
// response.setHeader('Cache-control', 'max-age=86400');
const fileMd5 = md5(cssStr);

response.setHeader('ETag', fileMd5);
const ifNoneMatch = request.headers['if-none-match'];
if (ifNoneMatch === fileMd5) {
  response.statusCode = 304;
} else {
  response.setHeader('Content-type', 'text/css; charset=utf-8');
  response.write(cssStr);
}

重點(diǎn)履怯!回还,下次刷新后,在request header中會(huì)出現(xiàn) If-None-Match字段叹洲。


image.png

后端在header獲得If-No-Match的值與fileMd5值相比較柠硕,如果不一樣說(shuō)明文件更新了,則后端繼續(xù)返回最新的文件运提。如果一樣蝗柔,則說(shuō)明不需要更新闻葵,返回code: 304和一個(gè)空的response。

cache-control: 直接不請(qǐng)求癣丧,用本地緩存笙隙。
eTag: 請(qǐng)求,比較md5值坎缭,一樣則返回空的相應(yīng)體,不一樣則返回最新的文件签钩。

Last-Modified&If-Modify-Since

last-modified

訪問(wèn)服務(wù)器時(shí)Request Header會(huì)自動(dòng)帶上If-Modified-Since字段掏呼,服務(wù)器會(huì)拿這個(gè)時(shí)間跟服務(wù)器文件最后更新時(shí)間去比,判斷是否需要更新铅檩。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末憎夷,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子昧旨,更是在濱河造成了極大的恐慌拾给,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件兔沃,死亡現(xiàn)場(chǎng)離奇詭異蒋得,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)乒疏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門额衙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人怕吴,你說(shuō)我怎么就攤上這事窍侧。” “怎么了转绷?”我有些...
    開封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵伟件,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我议经,道長(zhǎng)斧账,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任煞肾,我火速辦了婚禮其骄,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘扯旷。我一直安慰自己拯爽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開白布钧忽。 她就那樣靜靜地躺著毯炮,像睡著了一般逼肯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上桃煎,一...
    開封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天篮幢,我揣著相機(jī)與錄音,去河邊找鬼为迈。 笑死三椿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的葫辐。 我是一名探鬼主播搜锰,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼耿战!你這毒婦竟也來(lái)了蛋叼?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤剂陡,失蹤者是張志新(化名)和其女友劉穎狈涮,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鸭栖,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡歌馍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了晕鹊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片骆姐。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖捏题,靈堂內(nèi)的尸體忽然破棺而出玻褪,到底是詐尸還是另有隱情,我是刑警寧澤公荧,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布带射,位于F島的核電站,受9級(jí)特大地震影響循狰,放射性物質(zhì)發(fā)生泄漏窟社。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一绪钥、第九天 我趴在偏房一處隱蔽的房頂上張望灿里。 院中可真熱鬧,春花似錦程腹、人聲如沸匣吊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)色鸳。三九已至社痛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間命雀,已是汗流浹背蒜哀。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留吏砂,地道東北人撵儿。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像狐血,于是被迫代替她去往敵國(guó)和親淀歇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容