搭建Github Pages和Hexo博客
原文链接 https://vaniot-s.github.io/2017/12/29/%E6%90%AD%E5%BB%BAHexo%E5%8D%9A%E5%AE%A2/
注:以下为加速网络访问所做的原文缓存,经过重新格式化,可能存在格式方面的问题,或偶有遗漏信息,请以原文为准。
一、安装配置Git
1.安装git,下载地址。 git中文教程Pro git 2.配置用户信息:
$ git config --global user.name "vaniot"//用户名
$ git config --global user.email "vaniot@gmail.com"//填写自己的邮箱
3.配置SSH密钥 配置Github的SSH密钥可以让本地git项目与远程的github建立联系,让我们在本地写了代码之后直接通过git操作就可以实现本地代码库与Github代码库同步。 打开git本机是否存在SSH Keys检测
$ cd ~/. ssh //检测本机用户home目录下是否存在.ssh
若不存在此目录,创建一对新的SSH密钥
$ssh-keygen -t rsa -C "your_email@example.com"
#这将按照你提供的邮箱地址,创建一对密钥
#在此过程中会要求输入密码可选择不输入,及特定的文件名不输入则在默认的位置存储如/c/Users/you/.ssh/github_rsa
<!--more-->
二、安装node.js及hexo在本地
官网下载 安装完node后,打开git安装hexo命令工具
npm install hexo-cli -g #安装hexo命令行工具
创建Hexo文件夹,打开文件夹,打开文件夹使用git执行初始化
$ hexo init
$ npm install
为了避免出错安装以下插件
npm install hexo-generator-index --save
npm install hexo-generator-archive --save
npm install hexo-generator-category --save
npm install hexo-generator-tag --save
npm install hexo-server --save
npm install hexo-deployer-git --save
npm install hexo-deployer-heroku --save
npm install hexo-deployer-rsync --save
npm install hexo-deployer-openshift --save
npm install hexo-renderer-marked@0.2 --save
npm install hexo-renderer-stylus@0.2 --save
npm install hexo-generator-feed@1 --save
npm install hexo-generator-sitemap@1 --save
npm install hexo-generator-feed
在本地查看效果:
hexo generate
hexo server
登录localhost:4000,即可看到本地的效果如下:
三、Github Pages部署hexo
GitHub是基于git实现的代码托管,可以免费使用,Github Pages可以被认为是用户编写的、托管在github上的静态网页, 简单快捷,使用Github Pages可以为你提供一个免费的服务器,免去了自己搭建服务器和写数据库的麻烦。 1.注册github 2.创建代码库
ps:若要创建的博客地址与用户名相同则仓库名应与用户名相同即为:username.github.io 3.生成github pages 进入仓库setting->github pages->choose a theme 4.添加SSH Keys 进入个人主页Account Setting->SSH Keys将上述生成的SSH Keys的rsa_pub填入 5.测试 可以输入下面的命令,看看设置是否成功,git@github.com的部分不要修改:
$ ssh -T git@github.com
是下面的反馈:
The authenticity of host 'github.com (207.97.227.239)' can't be established.
RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.
Are you sure you want to continue connecting (yes/no)?
输入yes就好,然后会看到:
Hi cnfeat! You've successfully authenticated, but GitHub does not provide shell access.
6.修改配置文件,部署到github 打开Hexo文件找到_config.yml找到deploy修改:(确定已安装插件 npm install hexo-deployer-git --save)
deploy:
type: git
repository: https://github.com/Vaniot-s/vaniot-s.github.io.git ##你的仓库地址
branch: master
生成静态文件及部署博客:
hexo g -d
7.在浏览器上输入自己的主页地址
四、多台电脑同步更新Hexo博客
1.首先在另一台电脑上配置hexo、node、git及ssh密钥并将其上传到github上(如上操作) 2.在github的存储博客仓库创建新的分支(如取名:hexo)用于存放源代码,可将该分支作为默认的分支。将仓库克隆下来,
git clone https://github.com/Vaniot-s/vaniot-s.github.io.git
.gitignore 文件作用是声明不被 git 记录的文件,blog 根目录下的 .gitignore 是 hexo 初始化带来的,可以先删除或者直接编辑,对 hexo 不会有影响。建议 .gitignore 内添加以下内容:
/.deploy_git //hexo 默认的. git 配置文件夹,不需要同步 /public // 根据source文件夹内容自动生成,不需要备份,不然每次改动内容太多 /_config.yml //配置文件,根据自己需要是否添加,考虑到有外泄的可能,不建议上传
删除其中的文件除了.git,将博客的文件移入其中。执行提交的操作
git add .
git commit -m "new post hexo theme sync solution"
git push
五、更换hexo主题(多台电脑同步时的操作)
- 进入Hexo主题官网,选择喜欢的主题,第三方主题,与git中的submodule相关。按以下思路进行解决:进入到它的github地址,将其fork到你的的仓库,然后引入子模块,我这边不知道为什么有“already exists in the index”的问题,执行如下命令:
git rm -r --cached themes/hexo-theme-snippet
可能要修改自己的hexo-theme-snippet,为了不让它遗失,先剪贴出来,再添加submodlue:git submodule add https://github.com/Vaniot-s/hexo-theme-snippet.git themes/hexo-theme-snippet
然后再把自己的配置覆盖fork下来的hexo-theme-snippet仓库。先push submodule,在theme/next目录下依次执行:git add . git commit -m "modify themes" git push //这是提交到fork后主题的仓库
2.打开Hexo文件夹下的配置文件_config.yml,修改参数为:theme: hexo-theme-snippet,返回Hexo目录,右键Git Bash,输入hexo g hexo s
3.然后我们再更新vaniot-s.github.io仓库:cd ../../ //切到仓库的根目录 git add . git commit -m "update hexo-theme-snippet settings in blog sources branch" git push origin hexo //注意hexo分支
4.打开浏览器,输入 http://localhost:4000/ 即可看见主题已经更换.部署到Github上,打开Hexo文件夹,右键Git Bash,输入hexo clean (必须要,不然有时因为缓存问题,服务器更新不了主题) hexo g -d
5.另一台电脑上的操作git clone --recursive https://github.com/Vaniot-s/vaniot-s.github.io.git //clone 主仓库 cd vaniot-s.github.io/ git checkout hexo //切换到hexo,以后基本都是基于此分支,master分支用hexo -d cd themes/hexo-theme-snippet/ git submodule init git submodule update //获取我的hexo-theme-snippet主题的配置
6.之后便是使用git pull拉取合并 ### 六、Hexo写文章 1.Hexo支持Markdown语法创建Markdown的文章hexo new xxxxx
2.创建文章分类 scaffolds目录下,是新建页面的模板,执行新建命令时,是根据这里的模板页来完成的,所以可以在这里根据你自己的需求添加一些默认值。打开scaffolds/post.md文件,在tags:上面一行加入categories:,保存后,重新执行hexo n ‘name’命令,会发现新建的页面里有categories:项了 打开根目录下的配置文件_config.yml(注意不是themes主题目录下的_config.yml,那个文件叫 主题配置文件),找到如下位置做更改:# Category & Tag default_category: uncategorized category_map: web: web 基础: basic 工具: tool 资源: resource tag_map:
>category_map: 是设置分类的地方,每行一个分类,冒号前面是分类名称,后面是访问路径.但不是每个主题均可以设置
七、配置评论
开启Gitment评论,先去这里 注册一个新的 OAuth Application。其他内容可以随意填写,但要确保填入正确的 callback URL(一般是评论页面对应的域名,如 https://vaniot-s.github.io/ )。 得到一个 client ID 和一个 client secret,这个将被用于之后的用户登录。打开主题的设置文件_config.ymal找到:主题评论
gitment:
enable: true
owner: //github用户名
repo: //设置仓库
client_id:
client_secret:
labels:
perPage:
thanks to @imsun
八、hexo文章中引入emoji
1.安装
在博客目录下运行:
npm install https://github.com/frapples/hexo-article-emoji --save
#大陆用户最好使用阿里的镜像源:
npm install https://github.com/frapples/hexo-article-emoji --save --registry=https://registry.npm.taobao.org
之后,你需要把 emoji 的图片资源复制到你的 source 文件夹去,默认会复制到你的 source/images/emoji 文件夹。 在博客目录执行:
hexo article-emoji install
#实际上 emoji 图片有两个版本,默认只会复制精简版,复制完整版
hexo article-emoji install full
移除上面命令安装的图片,其实也就是删除 source/images/emoji 文件夹:
hexo article-emoji remove
2.配置
编辑 hexo 的配置文件 _config.yml,找到一下选项,改为 true :
post_asset_folder: true
使用完整版的 emoji 表情,你需要在 _config.yml 加入:
article_emoji:
full: true
3.使用
这里附上了 emoji 的语法和表情的对照表。输入:
I fell good! :simple_smile:
文章生成后,输出: I fell good! :smile: