provisional headers are shown 知多少

前言

請求裏面provisional headers are shown(顯示臨時報頭) 出現的狀況不少,但緣由是多樣的。
若是你去直接匹配關鍵字搜索,獲得的結果可能與你本身的狀況截然不同。
網上大部分都是在跨域時出現,或者是請求被插件攔截,但關於緩存時的請求不多。
我在上文查看緩存的時候發現了這個問題,當時查找資料都是聚焦於請求被攔截,
因此本文就簡單整理一下相關狀況。css

問題描述

當刷新頁面時,想要查看http請求header中相關信息時,
發現使用緩存的請求(from disk cache或者from memory cache)header相關信息不能查看html

第一次看到確實有點疑惑,那麼就去搜索了下。
碰到這個提示的狀況挺多,但細看下與咱們的場景不太符合。

基本上遇到的都是provisional headers are shown,阻止了請求的正常加載。
而咱們只是在使用緩存的時候遇到,而看起來請求沒有被block掉。好像不太符合。chrome

問題定位

雖然沒有看到匹配度十分相關的信息,但看到了有啓發的一篇文章(詳情點擊)跨域

摘抄部分以下:瀏覽器

The resource could be being blocked by an extension (AdBlock in my case).
The message is there because the request to retrieve that resource was never made, so the headers being shown are not the real thing. As explained in the issue you referenced, the real headers are updated when the server responds, but there is no response if the request was blocked.
緩存

資源可能被一些擴展程序攔截 。服務器

另外還有一句:app

I believe it happens when the actual request is not sent. Usually happens when you are loading a cached resource.chrome-devtools

真正請求並未被髮送,當使用緩存時常常發生。post

之因此會出現這個信息是由於獲取相關資源的請求並無發出,
因此headers被展現並非真正的信息。
就像提到的那樣,真正的header只有在服務端返回的時候會更新。
當請求被攔截後,並無返回。
基於這個狀況開始猜想緣由所在:

猜想1、請求跨域被攔截

雖然如今網站的靜態資源都會存在專門的靜態域名下面,和html域名可能不一致。
可是基本都是基於CORS來解決這個問題,因此不存在這個問題。
再有就是,咱們這種狀況首次請求的時候不會發生,若是有跨域,應該都被block。
另外若是是被攔截,那麼請求應該不會被響應的,咱們這裏顯然獲得了正確的響應。
這種被排除。

猜想2、服務器未及時響應

這種猜想和一差很少,特定狀況下才會出現,跟服務器關聯不大。

猜想3、被擴展程序攔截

做爲一個開發人員,你們的chrome上確定裝了很多的插件。這種緣由仍是有可能的。
咱們能夠經過 chrome://net-internals 來根據關鍵字查找相關請求,
而後具體去看相關狀態。
例如咱們http://xxdy.tech/css/main.css?v=5.1.4請求

能夠看到並無出現block,timeout等字段,只能看到比較明顯的DISK_CACHE。
所以這種狀況也不知足,咱們應該是和本地緩存強烈相關的。

本地緩存

結合上面的分析,咱們能夠縮小到緩存上面。衝着這個目標,咱們繼續去看下相關資料。
最後在一篇日文資料裏找到了相關解釋。
彷佛只從緩存中得到的通訊顯示爲「顯示臨時標題」(或「執行」)
由於該文件是從緩存中獲取的,而且未進行通訊
因此詳細標頭並不會顯示。

緣由:未與服務端正確通訊

回過頭來看,前面提到的那麼多狀況其實都是與服務器沒有進行或者完成正確的通訊,因此只展現臨時信息。

常見情況

provisional headers are shown出現的狀況有這麼幾種:

  1. 跨域,請求被瀏覽器攔截
  2. 請求被瀏覽器插件攔截
  3. 服務器出錯或者超時,沒有真正的返回
  4. 強緩存from disk cache或者from memory cache,此時也不會顯示

結束語

到這裏provisional headers are shown相關總結就結束了,自己並非一個問題,但在自身不瞭解的狀況下仍是要去研究一下,否則永遠是個問題。本文拋磚引玉,給本身一個總結,同時但願能給有須要人一些幫助。

參考文章

https://stackoverflow.com/questions/21177387/caution-provisional-headers-are-shown-in-chrome-debugger
https://did2memo.net/2017/01/23/chrome-devtools-provisional-headers-are-shown/
http://www.techfolks.net/provisional-headers-are-shown-in-google-chrome-browser-debugger/

相關文章
相關標籤/搜索