【转】provisional headers are shown 知多少
前言
请求里面provisional headers are shown(显示临时报头) 出现的情况很多,但原因是多样的。
如果你去直接匹配关键字搜索,得到的结果可能与你自己的情况大相径庭。
网上大部分都是在跨域时出现,或者是请求被插件拦截,但关于缓存时的请求很少。
我在上文查看缓存的时候发现了这个问题,当时查找资料都是聚焦于请求被拦截,
所以本文就简单整理一下相关情况。
问题描述
当刷新页面时,想要查看http请求header中相关信息时,
发现使用缓存的请求(from disk cache或者from memory cache)header相关信息不能查看
第一次看到确实有点疑惑,那么就去搜索了下。
碰到这个提示的情况挺多,但细看下与我们的场景不太符合。
基本上遇到的都是provisional headers are shown,阻止了请求的正常加载。
而我们只是在使用缓存的时候遇到,而看起来请求没有被block掉。好像不太符合。
问题定位
虽然没有看到匹配度十分相关的信息,但看到了有启发的一篇文章(详情点击)。
摘抄部分如下:
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.
资源可能被一些扩展程序拦截 。
另外还有一句:
I believe it happens when the actual request is not sent. Usually happens when you are loading a cached resource.
真正请求并未被发送,当使用缓存时经常发生。
之所以会出现这个信息是因为获取相关资源的请求并没有发出,
所以headers被展示并不是真正的信息。
就像提到的那样,真正的header只有在服务端返回的时候会更新。
当请求被拦截后,并没有返回。
基于这个情况开始猜测原因所在:
猜测一、请求跨域被拦截
虽然现在网站的静态资源都会存在专门的静态域名下面,和html域名可能不一致。
但是基本都是基于CORS来解决这个问题,所以不存在这个问题。
再有就是,我们这种情况首次请求的时候不会发生,如果有跨域,应该都被block。
另外如果是被拦截,那么请求应该不会被响应的,我们这里显然得到了正确的响应。
这种被排除。
猜测二、服务器未及时响应
这种猜测和一差不多,特定情况下才会出现,跟服务器关联不大。
猜测三、被扩展程序拦截
作为一个开发人员,大家的chrome上肯定装了不少的插件。这种原因还是有可能的。
我们可以通过 chrome://net-internals 来根据关键字查找相关请求,
然后具体去看相关状态。
例如我们http://xxdy.tech/css/main.css?v=5.1.4请求
可以看到并没有出现block,timeout等字段,只能看到比较明显的DISK_CACHE。
因此这种情况也不满足,我们应该是和本地缓存强烈相关的。
本地缓存
结合上面的分析,我们可以缩小到缓存上面。冲着这个目标,我们继续去看下相关资料。
最后在一篇日文资料里找到了相关解释。
似乎只从缓存中获得的通信显示为“显示临时标题”(或“执行”)
因为该文件是从缓存中获取的,并且未进行通信
所以详细标头并不会显示。
原因:未与服务端正确通信
回过头来看,前面提到的那么多情况其实都是与服务器没有进行或者完成正确的通信,所以只展示临时信息。
常见状况
provisional headers are shown出现的情况有这么几种:
- 跨域,请求被浏览器拦截
- 请求被浏览器插件拦截
- 服务器出错或者超时,没有真正的返回
- 强缓存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/
【转】provisional headers are shown 知多少的更多相关文章
- provisional headers are shown 知多少
前言 请求里面provisional headers are shown(显示临时报头) 出现的情况很多,但原因是多样的. 如果你去直接匹配关键字搜索,得到的结果可能与你自己的情况大相径庭. 网上大部 ...
- 请求头出现Provisional headers are shown
provisional headers are shown 知多少:https://juejin.im/post/5c00980751882518805add83 请求头出现Provisional h ...
- nginx : server_name localhost 和 chrome : Provisional headers are shown
问题相关问题现象:解决思路解决方案总结 问题相关 nginx : server_name localhost chrome : Provisional headers are shown 问题现象: ...
- Chrome 里的请求报错 "CAUTION: Provisional headers are shown" 是什么意思?
在调试器中看到文件显示提示为 CAUTION: Provisional headers are shown, 可是直接复制链接访问资源却可以正常访问, 最后发现是https 问题,资源采用ssl协议, ...
- chrome "Provisional headers are shown"
我的问题的,每次打开浏览器,点开有视频的页面(云平台的存储),然后当视频还没有加载完,就马上关闭,连续操作很多次(测试的暴力测试把),F12查看就有很多很多在加载中的连接,因为连续点击太多次了,第一个 ...
- 使用laravel-admin后台sdk报错Failed to load resource: net::ERR_CERT_AUTHORITY_INVALID、Provisional headers are shown
报错Failed to load resource: net::ERR_CERT_AUTHORITY_INVALID请先确定自己的资源url是否可以确实访问到(地址正确与否.访问权限是否开启等) 若n ...
- nginx Provisional headers are shown
项目用的Nginx做的代理,重启电脑后,重启项目和Nginx 浏览器报 Provisional headers are shown 解决: host文件添加: 127.0.0.1 cleaner ...
- 解决provisional headers are shown的过程
前言 学习Angular时写了一个音乐播放器oschina地址github地址为了兼容android chrome,参考了这篇文章; 在数据读取中要中断的时候,可以把audio.src设为null,并 ...
- Provisional headers are shown
问题: Chrome请求出现"Provisional headers are shown": 原因: 这种一般是由于浏览器端的插件或客户端的软件对请求进行了拦截:我们出现的情况,是 ...
随机推荐
- 超文本css样式换行
之前有关于LODOP中纯文本换行的相关博文:Lodop纯文本英文-等符号自动换行问题纯文本的遇到不拆分的单词的时候,可以通过LODOP 语句设置允许标点溢出,且英文单词拆开.超文本需要通过css样式控 ...
- SQL Delta实用案例介绍,很好的东西,帮了我不少忙
SQL Delta实用案例介绍 概述 本篇文章主要介绍SQL DELTA的简单使用.为了能够更加明了的说明其功能,本文将通过实际项目中的案例加以介绍. 主要容 SQL DELTA 简介 ...
- Python3之内建模块itertools
python的内建模块itertools提供了非常有用的用于操作迭代对象的函数 首先,我们看看itertools提供的几个无限迭代器 >>> import itertools > ...
- php+memcache高速缓存
原文地址:https://blog.csdn.net/qq_33571752/article/details/86494667 #在lnmp基础上修改 依赖libevent程序库 cd lnmp/ta ...
- nlp算法
人工智能算法大体上来说可以分类两类:基于统计的机器学习算法(Machine Learning)和深度学习算法(Deep Learning) 总的来说,在sklearn中机器学习算法大概的分类如下: 1 ...
- [转帖]MySQL latch小结
MySQL latch小结 https://www.cnblogs.com/liang545621/p/9439816.html 学习一下 一个是数据库内容 一个是内存内容 与oracle的读写锁 应 ...
- [转帖]AWS第一,「3A格局」稳固,活跃IP是如何被全球云厂商瓜分的?
AWS第一,「3A格局」稳固,活跃IP是如何被全球云厂商瓜分的? 本文作者:王刚 2019-02-24 10:42 https://www.leiphone.com/news/201902/qsz3c ...
- Spring Boot开启Druid数据库监控功能
Druid是一个关系型数据库连接池,它是阿里巴巴的一个开源项目.Druid支持所有JDBC兼容的数据库,包括Oracle.MySQL.Derby.PostgreSQL.SQL Server.H2等.D ...
- oracle安装内核参数设置
安装oracle内核参数说明及设置 kernel.shmmax 说明: Linux进程可以分配的单独共享内存段的最大值(byte) 64位的linux操作系统,设置应该大于SGA_MAX_TARGET ...
- AVR单片机教程——开发环境配置
今天去交大密院参观了设计展,无外乎两个主题:Arduino.Python. 关于Python,我印象最深的是一位Python程序员的话:你要硬核的话,可以去那边看Java. 拜托,都9102年了,Ja ...