环境配置|GitHub——解决Github无法显示图片以及README无法显示图片

一、问题背景

最近在整理之前写过的实验、项目,打算把这些东西写成blog,并把工程文件整理上传到Github上。但在上传README文件的时候,发现github无法显示README中的图片,如下图所示:

在README中该图片路径为:

复制代码
![contents](./contents.pdf)

而仓库的内容为:

其中,contents.pdf是论文的目录页,虽然是pdf格式,但是按照我的经验,LaTeX、markdown都是可以把pdf识别成高清矢量图的,因此在本地的README中,这个目录是会显示的,如下:

查阅百度百科:PDF(Portable Document Format的简称,意为"可携带文档格式"),是由Adobe Systems用于与应用程序、操作系统、硬件无关的方式进行文件交换所发展出的文件格式。PDF文件以PostScript语言图象模型为基础,无论在哪种打印机上都可保证精确的颜色和准确的打印效果,即PDF会忠实地再现原稿的每一个字符、颜色以及图象。因此,pdf可以是图像的后缀。

二、解决方法(记录了尝试过程,如不想看废话直接看方法总结)

查阅资料,发现github中README.md关联图片的图片地址是具有规范格式:

复制代码
https://github.com/用户名/repository仓库名/raw/分支名master/图片文件夹名称/***.png or***.jpg

如果没有图片文件夹,则可以直接省略此部分即可。于是,我尝试把图片地址改为:

复制代码
![contents](https://github.com/RGNil/2020MCM_paper/raw/master/contents.pdf)

但是依旧显示不了,难道是github不能显示pdf?于是我把pdf转换成了png图片

然后尝试了以下两个地址

复制代码
![contents](./contents.png)
![contents](https://github.com/RGNil/2020MCM_paper/raw/master/contents.png)

但是依旧显示不了,于是我想,干脆直接用图片的绝对地址试试

点击仓库的contents.png,找到图片地址,同时发现即使不在README中,还是无法显示该图片。尝试了一下绝对地址

复制代码
![contents](https://github.com/RGNil/2020MCM_paper/blob/master/contents.png)

但依旧不能在README中显示图片,淦。,。

点击链接查阅一下

发现无法访问,显示的地址开头是 raw.githubusercontent.com

查阅资料发现,raw.githubusercontent.com 是github用来存储用户上传文件(不是项目仓库的文件,而是issue里的图片之类的)的服务地址。放在亚马逊s3上。是github 的素材服务器 (assets server), 避免跟主服务抢占负载。

直接搜,发现好像是因为有 墙 的存在。,。

也有说是DNS污染了,这里简要介绍一下DNS 污染:网域服务器缓存污染(DNS cache pollution),又称域名服务器缓存投毒(DNS cache poisoning),是指一些刻意制造或无意中制造出来的域名服务器数据包,把域名指往不正确的IP地址。一般来说,在互联网上都有可信赖的网域服务器,但为减低网络上的流量压力,一般的域名服务器都会把从上游的域名服务器获得的解析记录暂存起来,待下次有其他机器要求解析域名时,可以立即提供服务。一旦有关网域的局域域名服务器的缓存受到污染,就会把网域内的计算机导引往错误的服务器或服务器的网址。

尝试配置hosts文件,直接指向github的服务器。用ipaddress查一下raw.githubusercontent.com 的ip

修改hosts文件,mac的hosts在

复制代码
/etc/hosts

添加

复制代码
199.232.68.133 raw.githubusercontent.com
199.232.68.133 githubusercontent.com

如果不习惯直接命令行修改,可以使用SwitchHosts工具(mac、win都适用)

添加hosts配置

添加github相关host

添加之前的配置并开启该配置

这里再赘述一句,如果不需要这个hosts可以直接关掉,如果需要注释某一行配置,只需要单击配置前行号即可

好了,搞了一圈,看看github能不能显示图片了:

激动人心!!!终于可以显示图片了!!!

经过测试,之前的几种路径格式都可以,如此一来就用最简单的相对路径就好了(下述第一行)

复制代码
![contents](./contents.png)
![contents](https://github.com/RGNil/2020MCM_paper/raw/master/contents.png)
![contents](https://github.com/RGNil/2020MCM_paper/blob/master/contents.png)

然而,github的README好像还是不支持把pdf显示,下面的一行仍旧不显示

复制代码
![contents](./contents.pdf)

三、方法总结

所以不管是README不能显示图片,还是github网站上不能显示图片,并不是图片路径格式的问题,而是DNS污染了,即无法访问存放了github图片素材的raw.githubusercontent.com站点。

解决方法很简单,查找raw.githubusercontent.com的ip,并将其添加至系统hosts文件即可:

用ipaddress查一下raw.githubusercontent.com 的ip

修改hosts文件,添加github相关host

添加之前的配置并开启该配置

然后就可以正常显示github上所有的图片了!!

相关推荐
编程修仙11 小时前
github的使用
github
白驹过隙^^12 小时前
OB-USP-AGENT安装使用方法
数据库·经验分享·网络协议·tcp/ip·github·ssl
xlp666hub12 小时前
手写 Linux 并发服务器,fork, pthread与 epoll 模型实战(包含深层原理剖析)
github·c
火车叼位14 小时前
小白也能学会:AI分离人声 + FFmpeg替换音轨全流程
github
程序媛Dev14 小时前
平台工程新范式:我扔掉了本地环境,开发体验直接起飞。
github
逛逛GitHub14 小时前
这个 GitHub 神器让 Gemini 写的网站 3 秒上线,累计部署 67 万个网站。
github
GZKPeng15 小时前
github 新版本网页如何对repository管理人员
github
CoderJia程序员甲19 小时前
GitHub 热榜项目 - 日榜(2025-12-16)
llm·github·ai教程
bj_zhb19 小时前
Git 回退到某个 commit
git·github
openinstall全渠道统计20 小时前
开发者指南:广告投放系统搭建与前后端数据打通全流程
windows·git·oracle·eclipse·sqlite·github