使用hexo+github免费搭建个人博客网站超详细教程

参考依据

优点
1、不需要服务器,github免费提供的托管服务
2、不需要域名,github同样提供了一个.io的域名
3、不用自己写xml、hexo提供了很多开源的博客模板。
4、便于维护更新,换风格直接换模板就行。

安装相关工具

1、安装Node.js

nodejs官网
普通用户建议安装稳定版(第一个)

2、安装Git

git官网

打开cmd命令行(win+r 输入cmd回车)分别执行,查看是否安装成功

node -v
npm -v
git --version

安装hexo时,nodejs和git版本有一定的关系,建议都安装最新的稳定版本

会得到相对应的版本信息(如图)
wapchief
如果都可以成功运行出现版本信息证明安装成功。
这里写过一篇介绍git的文章,如果安装遇到问题可以去查看:
《必须要会的Git基本使用及常用命令操作》

3、安装Hexo

必须按照步骤来,因为hexo需要使用node.js的npm命令。
打开cmd命令行(win+r 输入cmd回车)分别执行

npm install hexo-cli -g

等待自动安装完成后。输入

hexo -v

检查是否安装成功
到这一步如果所有都安装成功,并测试无问题,那么本地配置已经搞定,下面开始在github上建项目了。

在github上创建并设置远程库

注册登录略过,不会的请自行百度。
登录后点击“+”号,选择New repository,下一步
在Repository name下面填写你要创建的地址,这个地址是就是你的域名,以github.io结尾。例如填写pgxie.github.io以后就在地址栏直接输入pgxie.github.io就可以访问网站
按照提示一步步完成创建。
创建之后,点击setting设置远程库:
找到GitHub Pages点击Automatic page generator
等待github pages创建完成,然后输入你创建的地址测试github pager是否创建成功。此时页面是空的没有任何东西。
wapchief
下面要做的就是使用hexo模板将源码放到github。

初始化Hexo

创建一个文件夹用于存放hexo。然后右键该文件夹使用

git bash here

命令就可以直接定位到当前目录。
wapchief
然后使用

npm install hexo --save

初始化hexo基础配置文件。初始化时间比较长,不用急,等完成后输入

hexo init

初始化hexo。这个命令和git 仓库命令相似。意思一样都是初始化。
接着输入

npm install

配置node。然后输入

hexo g

加载hexo基础html、css、js等文件。
在这完成后等于已经在本地创建了一个网页,想查看的话,输入

hexo s

然后相当于开启了一个本地的服务器,会提示你拷贝url到浏览器。
(如图)
wapchief在浏览器输入 http://localhost:4000/
会看到这样的页面,证明本地hexo默认模板配置成功,
wapchief
到这一步如果将hexo放到github page,那么使用github.io访问的将是一个默认的页面。下面我们要把他diy成自己的博客,包括导入模板主题等。

安装主题

关于主题大多都是以压缩包形式,可以去github上搜hexo theme或者hexo官网找,会出来很多,里面都有介绍。

可以通过两种方法下载,比如安装hexo-theme-butterfly
主题

  1. 直接直接下载压缩包
  • code ->download zip
  1. 直接使用git命令,在本地hexo目录输入
git clone https://github.com/jerryc127/hexo-theme-butterfly.git themes/next

等待下载完成。如果出现失败的提示,有可能是网络环境不好。重试即可。
下载完主题后,将主题文件夹房子themes目录下,(git下载会直接放到该目录下)

接下来回到hexo根目录下用记事本打开\_config.yml文件。
把landscape修改成与themes下主题名字相对应的名称。

然后再运行

hexo s

打开浏览器地址栏输http://localhost:4000/
现在是我们修改主题后的页面。

修改内容

内容较多建议参考官方文档

修改完之后,可以重新执行hexo s在浏览器查看效果。并确认无误,包括以后需要添加文章,或者更新主题等,都建议先在本地查看无误再远程部署。
项目根目录_config.yml文件中:

# Site
title: 网站标题
subtitle: 副标题
description: 个人签名
author: 姓名
language: zh-Hans
timezone:

另外需要看一下主题的README帮助文档,一般是再主题内的_config.yml,不过少部分可能需要在根目录的_config.yml修改

这里有几个坑需要注意一下:

1、所有的配置“:”符号后面都要带空格,否则执行本地测试直接失败。
2、language是设置语言。zh-CN是中文。
3、如果设置zh-CN后仍出现乱码问题。需要更改文件的字符编码集为UTF-8,方法很多具体,就不详细介绍了。

注意同时要在,根_config.yml中配置自己的远程仓库地址

deploy:
  type: git
  repo: https://github.com/pgxie/pgxie.github.io
  branch: master

这一步很关键,不要漏了。

提交项目,部署

继续在本目录命令行
安装部署工具(方便以后更新)
npm install hexo-deployer-git -save
1、初始化本地仓库:
git init
2、连接远程仓库:
如果是第一次使用git,在使用git的时候会提示输入用户名和密码,用户名是自己的注册邮箱。(如果用户名密码登录不成功,可以重新操作,然后用token验证,详情看这篇博客
git remote add origin https://github.com/pgxie/pgxie.github.io
3、发布hexo到github page
hexo clean && hexo g && hexo d
4、添加文件到本地仓库
git add
5、提交声明
git commit -m '内容'
6、推送到远程仓库(github)
这里建议创建一个新的分支hexo,用于管理hexo文件。提交的的时候只提交hexo网站html、css、等源文件。
创建并切换到新建分支:
git checkout -b hexo
将分支推送到远程仓库:
git push origin hexo
这时打开网站就能看到效果了。

记得提交以后去github上把hexo分支设置默认,以后写文章等都要部署。
文章在hexo目录下的\source_posts文件夹中,是md格式,也就是Markdown格式。
以后可以用以下命令部署。也就是第三步

//等于一次性执行了,清空、刷新、部署三个命令
hexo clean && hexo g && hexo d

如果部署时不clean,可能之前修改的文章还存在。包括一些配置等,有时候部署完成后并没有改变,其实是缓存未清除。

进阶-绑定域名

域名可以自行去阿里云,景安等网站购买。一般都有系统提示步骤。
拿到域名之后,进行解析,推荐使用dnspod免费解析。
具体使用方法:
1、注册登录dnspod之后,添加域名,然后解析,添加两条记录


2、登录你注册域名网站的管理后台,修改DNS解析地址为

f1g1ns1.dnspod.net
f1g1ns2.dnspod.net

3、登录github,找到项目,设置setting,找到GitHub Pages
wapchief

4、在master分支下的CNAME.MD文件写入注册的域名
wapchief

再次访问差不多就好了,如果延迟的话,可能解析立马不会生效。需要等会儿才能看到。