前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【最新】解决Github网页上图片显示失败的问题

【最新】解决Github网页上图片显示失败的问题

作者头像
全栈程序员站长
发布2022-09-05 10:07:04
3.8K0
发布2022-09-05 10:07:04
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

目录

好几个星期之前本人就发现自己的 github在网页打开显示不了图片的问题了,不过当时没在意。

今天强迫症逼迫我一定要搞定它,于是去找了一些方法,自己做个记录,有相同问题的伙伴可以参考一下。

一、问题

比如随便打开一个项目,图片都不能显示了,我头像也没了,真是一个令人伤心的事

在这里插入图片描述
在这里插入图片描述

F12打开控制台看一哈

在这里插入图片描述
在这里插入图片描述

呦,一堆红色×。主要报错是Failed to load resource: net::ERR_CERT_COMMON_NAME_INVALID

去查了一下,博主john-zeng这样解释道:

实际上,可以认为,ERR_CERT_COMMON_NAME_INVALID就是用一个错误的域名访问了某个节点的https资源。导致这个错误的原因,基本是:

  1. dns污染
  2. host设置错误
  3. 官方更新了dns,但是dns缓存没有被更新,导致错误解析。

我觉得像是有点道理,解决方法就粗来了,hin简单,往下看。

二、解决方法

主要思路就是使用本地hosts文件对网站进行域名解析,一般的DNS问题都可以通过修改hosts文件来解决,githubCDN域名被污染问题也不例外,同样可以通过修改hosts文件解决,将域名解析直接指向IP地址来绕过DNS的解析,以此解决污染问题。

2.1 找到URL

打开github任意未显示图片的网页,使用元素选择器(Ctrl+Shift+C)放在显示不了的图片上,或者在无法显示的图片上右键-检查元素,定位到该图片的标签,那么你得到了它的URL,叫做src属性。

比如介个

在这里插入图片描述
在这里插入图片描述

在右面把它的网址复制粗来:

https://avatars2.githubusercontent.com/u/15832957?s=60&v=4

2.2 获取IP地址

得到上述网址以后打开IPAddress.com这个网站,在搜索框输入它的域名,就是https://com那一部分,俗称二级域名:

avatars2.githubusercontent.com

在这里插入图片描述
在这里插入图片描述

回车!!!下面你会看到该域名的信息和IP地址:

在这里插入图片描述
在这里插入图片描述

可以看出IP是:151.101.184.133,并且是2019.05.05最后更新的,alright,那么我们就可以使这个IP域名映射起来。

(其他如果有挂掉的图片一样使用此方法进行一一映射即可。)

2.3 修改hosts

具体咋映射呢?修改hosts文件!!!本人使用的是windows系统,所以使用Sublime Text打开:C:\Windows\System32\drivers\etc\hosts

在文件末尾添加:

在这里插入图片描述
在这里插入图片描述

可以直接选中以下内容复制粘贴,20210119有效(包括MAC系统)20210123更新

代码语言:javascript
复制
# GitHub Start 
140.82.113.3      github.com
140.82.114.20     gist.github.com

151.101.184.133    assets-cdn.github.com
151.101.184.133    raw.githubusercontent.com
199.232.28.133     raw.githubusercontent.com 
151.101.184.133    gist.githubusercontent.com
151.101.184.133    cloud.githubusercontent.com
151.101.184.133    camo.githubusercontent.com
199.232.96.133     avatars.githubusercontent.com
151.101.184.133    avatars0.githubusercontent.com
199.232.68.133     avatars0.githubusercontent.com
199.232.28.133     avatars0.githubusercontent.com 
199.232.28.133     avatars1.githubusercontent.com
151.101.184.133    avatars1.githubusercontent.com
151.101.108.133    avatars1.githubusercontent.com
151.101.184.133    avatars2.githubusercontent.com
199.232.28.133     avatars2.githubusercontent.com
151.101.184.133    avatars3.githubusercontent.com
199.232.68.133     avatars3.githubusercontent.com
151.101.184.133    avatars4.githubusercontent.com
199.232.68.133     avatars4.githubusercontent.com
151.101.184.133    avatars5.githubusercontent.com
199.232.68.133     avatars5.githubusercontent.com
151.101.184.133    avatars6.githubusercontent.com
199.232.68.133     avatars6.githubusercontent.com
151.101.184.133    avatars7.githubusercontent.com
199.232.68.133     avatars7.githubusercontent.com
151.101.184.133    avatars8.githubusercontent.com
199.232.68.133     avatars8.githubusercontent.com
199.232.96.133     avatars9.githubusercontent.com

# GitHub End

然后保存文件就OK了,至于无法保存,没有修改权限,鼠标右键-属性-安全-修改权限;或将hosts文件复制一份,修改之后,复制到原文件夹替换!

三、最后说几句

还可以使用ipconfig/flush对本地DNS缓存进行一次刷新,如果遇到网络异常,可能是DNS缓存的问题,刷新一下,步骤。

  1. windows开始→运行→输入:CMD 按回车键,打开命令提示符窗口。
  2. 再输入: ipconfig /flushdns 回车,执行命令,可以重建本地DNS缓存。

再附上几个命令:

代码语言:javascript
复制
ipconfig /displaydns # 显示dns缓存 

ipconfig /flushdns # 刷新DNS记录 

ipconfig /renew # 重请从DHCP服务器获得IP 

PS:另外要注意的一点就是,如果图片再次不能显示,只需要及时更新IP就行啦,这波操作不麻烦,你看我头像回来了!!!

JevenM
JevenM
JevenM-lixian
JevenM-lixian

哈哈哈,没错,是李现

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/136907.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年6月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 目录
  • 一、问题
  • 二、解决方法
    • 2.1 找到URL
      • 2.2 获取IP地址
        • 2.3 修改hosts
        • 三、最后说几句
        相关产品与服务
        内容分发网络 CDN
        内容分发网络(Content Delivery Network,CDN)通过将站点内容发布至遍布全球的海量加速节点,使其用户可就近获取所需内容,避免因网络拥堵、跨运营商、跨地域、跨境等因素带来的网络不稳定、访问延迟高等问题,有效提升下载速度、降低响应时间,提供流畅的用户体验。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档