查错之旅 GitHub排版混乱--特定浏览器加载时错误

2024-01-27 01:58

本文主要是介绍查错之旅 GitHub排版混乱--特定浏览器加载时错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前面的话:

上一次打开Github也就是两三天内的事情,莫名其妙的,今天再打开排版会很混乱,本以为是个小问题,可Google之后竟没有一个简单的解释,纠错之旅,磕磕绊绊。

错误效果截图:

这里写图片描述

纠错尝试

1. 网络切换–失败

这种没加载好的问题,最简单的是网络不好,但换了好几个网络过后,一如既往…

2. 第三方浏览器尝试连接GitHub–成功

居然在Edge上能正常访问,那就是chrome的锅了,想不到你也有今天。
(不过还不好说,最近更新了一次win,说不定是被微软强暴了)

3. 关闭chrome插件–失败

chrome这种神器,怎么能背锅呢,一定是插件冲突了,(不想跟你讲道理,并向你扔了一口锅)。然而失败了,关闭了各种插件,尤其是最可能的广告拦截,仍然不起作用。

4. 修改hosts–失败

无奈之下,上Google看了看,可惜对前端没有太多了解,关键词可能出问题了。总之,一番搜索下来,最有可能的是这个解释:

github的DNS被GFW污染了
之前为了翻墙,改了系统hosts文件下github的DNS解析。

乍一看很有道理,可要是这样的话,其他浏览器应该也加载不了。
果然,改完hosts也没有用。

5. 清除Cookie及其它网页数据–成功!!!

我查看了chrome与Microsoft Edge对GitHub.com的加载情况,差异是这个:

chrome :
这里写图片描述

这是Microsoft Edge 的对应信息
这里写图片描述

于是,我试着访问

“https://assets-cdn.github.com/assets/frameworks-592c4aa40e940d1b0607a3cf272916ff.css” ,

惊奇地发现:chrome禁止我访问,而Edge能下载一个110kb的文件。

我确信是chrome出了问题,于是我查看chrome的各项设置情况,看见了“清除Cookie及其他网站信息”这一项,这是很有可能的问题。
我清除Cookie数据后再次访问,果然成功了。

总结与吐槽:

幸好我了解一点Cookie相关的皮毛,不然会更坑。

下面这段摘自维基百科,介绍一下Cookie的用途:

因为HTTP协议是无状态的,即服务器不知道用户上一次做了什么,这严重阻碍了交互式Web应用程序的实现。在典型的网上购物场景中,用户浏览了几个页面,买了一盒饼干和两瓶饮料。最后结帐时,由于HTTP的无状态性,不通过额外的手段,服务器并不知道用户到底买了什么,所以Cookie就是用来绕开HTTP的无状态性的“额外手段”之一。服务器可以设置或读取Cookies中包含信息,借此维护用户跟服务器会话中的状态。在刚才的购物场景中,当用户选购了第一项商品,服务器在向用户发送网页的同时,还发送了一段Cookie,记录着那项商品的信息。当用户访问另一个页面,浏览器会把Cookie发送给服务器,于是服务器知道他之前选购了什么。用户继续选购饮料,服务器就在原来那段Cookie里追加新的商品信息。结帐时,服务器读取发送来的Cookie就行了。Cookie另一个典型的应用是当登录一个网站时,网站往往会请求用户输入用户名和密码,并且用户可以勾选“下次自动登录”。如果勾选了,那么下次访问同一网站时,用户会发现没输入用户名和密码就已经登录了。这正是因为前一次登录时,服务器发送了包含登录凭据(用户名加密码的某种加密形式)的Cookie到用户的硬盘上。第二次登录时,如果该Cookie尚未到期,浏览器会发送该Cookie,服务器验证凭据,于是不必输入用户名和密码就让用户登录了。

简单来说,就是通过一个Cookie形式的验证后,网站知道你是谁,在他那里做过什么事,依次来方便与客户之间的交互。

在这次坑爹之旅中,

  • GitHub在加载中通过检测Cookie,发现我之前通过chrome访问过
  • 既然加载过,chrome里应该存有GitHub的排版格式信息,那GitHub就不给你发了,自己上缓存找去(总不能每次都发排版格式嘛,网络多累啊)
  • 出于某种不为人知的原因,我的排版格式丢失了,GitHub以为我在骗他,觉得我有文件,偷懒不给我重发(为了加速网络)
  • 最后单单chrome加载错误,而Edge没有问题

补:

最后理论有点问题,因为我成功访问之后,再次尝试访问

https://assets-cdn.github.com/assets/frameworks-592c4aa40e940d1b0607a3cf272916ff.css

是能够得到格式文件的,也就是说可能并不是通过判断是否访问过决定的。
之前可能只是我没有通过cookie验证,
但也有可能是chrome的机制做的自动加载。

精力有限,前端的东西只能暂时告一段落,希望有高手普及一下这方面的知识。

这篇关于查错之旅 GitHub排版混乱--特定浏览器加载时错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/648724

相关文章

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

Python struct.unpack() 用法及常见错误详解

《Pythonstruct.unpack()用法及常见错误详解》struct.unpack()是Python中用于将二进制数据(字节序列)解析为Python数据类型的函数,通常与struct.pa... 目录一、函数语法二、格式字符串详解三、使用示例示例 1:解析整数和浮点数示例 2:解析字符串示例 3:解

CentOS 7 YUM源配置错误的解决方法

《CentOS7YUM源配置错误的解决方法》在使用虚拟机安装CentOS7系统时,我们可能会遇到YUM源配置错误的问题,导致无法正常下载软件包,为了解决这个问题,我们可以替换YUM源... 目录一、备份原有的 YUM 源配置文件二、选择并配置新的 YUM 源三、清理旧的缓存并重建新的缓存四、验证 YUM 源

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

如何关闭Mac的Safari通知? 3招教你关闭Safari浏览器网站通知的技巧

《如何关闭Mac的Safari通知?3招教你关闭Safari浏览器网站通知的技巧》当我们在使用Mac电脑专注做一件事情的时候,总是会被一些消息推送通知所打扰,这时候,我们就希望关闭这些烦人的Mac通... Safari 浏览器的「通知」功能本意是为了方便用户及时获取最新资讯,但很容易被一些网站滥用,导致我们

python3 pip终端出现错误解决的方法详解

《python3pip终端出现错误解决的方法详解》这篇文章主要为大家详细介绍了python3pip如果在终端出现错误该如何解决,文中的示例方法讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下... 目录前言一、查看是否已安装pip二、查看是否添加至环境变量1.查看环境变量是http://www.cppcns

python进行while遍历的常见错误解析

《python进行while遍历的常见错误解析》在Python中选择合适的遍历方式需要综合考虑可读性、性能和具体需求,本文就来和大家讲解一下python中while遍历常见错误以及所有遍历方法的优缺点... 目录一、超出数组范围问题分析错误复现解决方法关键区别二、continue使用问题分析正确写法关键点三

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题

《Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题》:本文主要介绍Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录一、前言二、系统架构检测三、卸载旧版 Go四、下载并安装正确版本五、配置环境变量六、验证安装七、常见

正则表达式r前缀使用指南及如何避免常见错误

《正则表达式r前缀使用指南及如何避免常见错误》正则表达式是处理字符串的强大工具,但它常常伴随着转义字符的复杂性,本文将简洁地讲解r的作用、基本原理,以及如何在实际代码中避免常见错误,感兴趣的朋友一... 目录1. 字符串的双重翻译困境2. 为什么需要 r?3. 常见错误和正确用法4. Unicode 转换的