昨天重新申请了我自己名字全拼的域名 chenhuichao.com,然后把之前的 iamsuperman.cn 的国内域名给替换了。
换完之后才发现一个问题:如何让原有散落在各大搜索引擎和社交网站上的博客地址及 GitHub 多个 demo 地址也能保持正常访问?

最开始的想法是将 www.iamsuperman.cn 通过 CNAME 指向到 chenhuichao.com 这个域名。想法很美好,现实很骨感。作为一个使用 GitHub Pages 搭建的博客,只能遵循 GitHub Pages 的规则。
根据 GitHub Pages 的官方文档,一个 username.github.io 只能支持一个域名。

虽然官方不提供设置多个域名的方法,但是曲线救国的方式还是有的。
我们可以通过 cloudflare.com 提供的免费CDN 做转发。思路如下(这里假设你之前用过 cloudflare,如果不会的话,可以先看最下面的那篇文章):

  • 新建一个 GitHub 账号,再开一个 chaoren66.github.io repository(这里的 chaoren66 换成你的 GitHub 账号)
  • www.iamsuperman.cn 解析到 chaoren66.github.io
  • www.iamsuperman.cn 绑定到 cloudflare
  • 在 cloudflare 中设置 page rule:Forward Url(Status Code 301),所有访问 www.iamsuperman.cn 的请求都将转发至新域名 chenhuichao.com

但是这样只能解决当用户访问首页也就是 https://www.iamsuperman.cn 的时候,才能正确转发到新的域名。如果用户访问的是具体的某篇文章的url,由于在 新开的 github.io 上没有对应的url,所以导致访问会报404。

所以我的解决方案是:superman66.github.io 下的博客放到 chaoren66.github.io 上,重新部署一份博客。然后在这个新的博客上,添加提示信息及跳转到新域名的逻辑

这样就可以完美解决 博客启用新域名,同时保持网络上旧的域名链接仍然有效 的问题。

此外,你也还可以通过 cloudflare 来为你的博客全站启用 HTTPS。网上教程比较多,也很详细,我就不细说了。具体看这篇文章就够了:为自定义域名的GitHub Pages添加SSL 完整方案