热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[836]详解Provisionalheadersareshown

前言我们在发送异步请求遇到问题的时候,都会先打开Chrome的控制台来看一下http请求,有时候会在请求头看到Provisionalheadersar

前言

我们在发送异步请求遇到问题的时候,都会先打开Chrome的控制台来看一下http请求,有时候会在请求头看到Provisional headers are shown的报错

image

问题描述:

这个问题字面意思是“显示了临时报文头”,浏览器第一次发送这个请求,请求被阻塞,未收到响应。当要求浏览器再次发送这个请求时,上个同样的请求都还没有收到响应,浏览器就会报这个警告。

简而言之,就是请求并没有发出去

原因分析

这种情况出现的情况很多,但原因是多样的,一般有如下几种:

1. 跨域请求被浏览器拦截

现在网站的静态资源都会存在专门的静态域名下面,和实际访问的域名可能不一致。

这种情况基本发生在ajax请求,都是基于CORS来解决这个问题。

$.ajax({url: ajaxUrl,type: 'GET',success: function (res) {}});

可以替换为

$.cors(ajaxUrl, {}, function (json) {if (json.code == 0) {}});

2. 服务器未及时响应(超时)

这种特定情况下才会出现,跟服务器关联不大。

3. 请求被浏览器插件拦截

作为一个开发人员,大家的chrome上肯定装了不少的插件。我们可以通过 chrome://net-internals,这个地址已弃用,新地址:chrome://net-export/
,来根据关键字查找相关请求,然后具体去看相关状态。另外,被浏览器拦截,可以换个浏览器试试。

处理方式:调用chrome的  chrome://net-internals/#events ,然后重新触发一下请求,然后查看出现 Provisional headers are shown 的请求的日志;

查看是否存在 delegate_blocked_by 的关键字;这种一般是由于浏览器端的插件或客户端的软件对请求进行了拦截;我们出现的情况,是被 websense endpoint拦截;

如果是这种情况,基本上可以忽略啦,客户端自身的问题啦;可以考虑将插件或软件卸载后,重新尝试,看是否还出现;

4. 该数据直接采用了缓存,并没有发送请求

只从缓存中获得的通信显示为“显示临时标题”(或“执行”),因为该文件是从缓存中获取的,并且未进行通信,所以并不会显示详细标头。

如果上一个资源加载失败,可能导致从缓存加载的资源失败,即缓存资源请求之前的请求不能失败。强缓存from disk cache或者from memory cache,此时也不会显示。

前面提到的那么多情况,其实都是与服务器没有进行或者完成正确的通信,所以只展示临时信息。

扩展


CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing),它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制,以避开浏览器的同源策略,是 JSONP 模式的现代版。

与 JSONP 不同,CORS 除了 GET 要求方法外,也支持其他的 HTTP 请求。用 CORS 可以让网页设计师用一般的 XMLHttpRequest,这种方式的错误处理比 JSONP 好。另一方面,JSONP可以在不支持 CORS 的老旧浏览器上运作,现代浏览器都支持 CORS。

来源:https://www.jianshu.com/p/4cfa40121ecf
https://blog.csdn.net/starsnow123/article/details/78675240


推荐阅读
author-avatar
早安丶晚安丶英语连_691
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有