【转载】Hexo+GitHub构建个人博客

本文详述了如何利用Hexo框架和GitHub搭建个人博客的步骤,包括安装Node.js、Hexo、Git,配置SSH,上传博客静态文件至GitHub Pages,以及设置博客源文件仓库。通过跟随教程,读者可以快速创建并部署自己的Markdown格式的博客。
摘要由CSDN通过智能技术生成

原文地址:https://www.namidame.tech/Hexo+GitHub_build_blog.html

本篇教程讲述如何用Hexo和GitHub搭建一个静态博客。

一、安装Node.js

  • 到Node.js官网下载最新版本安装。本教程使用6.3.0版本。
  • 安装完毕后打开命令行,输入
node -v

若正常显示版本号,则安装成功
在这里插入图片描述

二、安装Hexo

Hexo是一个快速、简洁且高效的博客框架,支持Markdown格式编写,能够快速构建、部署博客。

  • 创建一个文件夹,你的博客文件将存放在此文件夹内,例如E:/MyBlog
  • 进入MyBlog文件夹,shift+右键弹出菜单,点击"在此处打开命令窗口",输入命令在全局安装hexo框架
npm install hexo-cli -g
  • hexo安装完成后,输入
hexo init

程序将自动克隆GitHub上的hexo初始工程到目录中,并安装package.json里默认的依赖包

  • 测试Hexo博客。输入命令
hexo server

本地测试默认监听4000端口,开启后显示以下信息则启动成功
在这里插入图片描述

还可以使用以下命令启动博客,以输出更详细的启动信息

hexo server --debug

服务器启动后会自动监听文件改变,大部分改变在文件保存后直接访问localhost:4000即可查看效果。
也可以使用以下简化命令来启动博客

hexo s

三、安装Git

  • 网上很多教程推荐在msysgit.github.io下载,但是我访问不了。我推荐在git-scm.com下载。本教程使用Git-2.12.2-64-bit版本。一般安装一直往下一步点就行。
  • 安装完毕在命令行输入命令,显示git版本号则成功安装
git --version

在这里插入图片描述

四、使用GitHub托管你的博客

GitHub提供GitHub Pages服务,为你建立的每一个项目提供专有的页面给其他人访问,如果我们将博客生成的静态HTML文件等内容布置到GitHub Pages上,那么其他人就可以访问这个页面来阅读你的博客,相当于一个服务器的作用。

假设你的GitHub用户名为yourname,那么如果你想建立你的GitHub个人主页,可以新建一个名为yourname.github.io的仓库,这样GitHub会为你生成一个名为yourname.github.io/的页面作为你的个人主页。而其他名字的仓库(例如other)生成的GitHub Pages则会是yourname.github.io/other/的地址形式。

我们需要建立两个repository,一个是用来存放博客的源代码,另一个用来存放博客生成的静态文件。我的博客源代码存放在https://github.com/drawfromwreck/BlogSource,博客静态文件存放在https://github.com/drawfromwreck/drawfromwreck.github.io中,于是我建立的两个仓库名字分别为"drawfromwreck.github.io"和"BlogSource"。

  • 首先在GitHub上申请自己的帐号。

  • 申请好之后,在主页点击Start a project建立新的代码仓库(repository)
    在这里插入图片描述

  • 输入你所设定的两个仓库名字,本教程中分别为"drawfromwreck.github.io"和"BlogSource"。这样GitHub仓库就创建好了。

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

五、配置SSH

  • 在E:/MyBlog/里点击鼠标右键,点击"Git Bash Here"
  • 输入命令
cd ~/.ssh

如果目录不存在,则创建目录

cd ~/
mkdir .ssh
  • 进入.ssh目录,生成ssh证书
cd ~/.ssh
ssh-keygen -t rsa -C "your e-mail"

这里的-t表示type为rsa加密,-C(Common)表示生成的key最后加上你GitHub帐号的邮箱名,以提示这段加密串是属于哪个帐号的。

  • 提示选择保存证书的文件名,直接回车使用默认值
    在这里插入图片描述

  • 提示设置passphrase,此密码以后每次提交的时候需要输入。再次输入以确认密码,则成功创建证书。
    在这里插入图片描述

  • 查看ssh公钥

cat id_rsa.pub

在这里插入图片描述

  • 点击GitHub右上角的用户头像,点击Settings,点击右侧的SSH and GPG keys,点击右上角的New SSH key加入新的ssh证书。Title我设置成为home表示这是家里的电脑提交时用的证书,Key里粘贴上刚刚生成的ssh公钥,记得把最后加上的邮箱名去掉。
    在这里插入图片描述

六、上传博客静态文件

  • 配置_config.yml文件。用文本编辑器打开博客根目录下的_config.yml文件,拉到最下面,如图设置
    在这里插入图片描述

deploy表示发布设置,type选择git发布,repo表示仓库地址的配置,这里我们按如下格式填写,yourname表示你的GitHub用户名,master表示发布到仓库的master分支。

github:git@github.com:yourname/yourname.github.io.git,master
  • 安装hexo的git发布工具
npm install hexo-deployer-git
  • 生成静态文件并发布到GitHub仓库。输入以下其中一种命令,hexo便会生成public文件并将public文件夹内容发布到仓库
hexo d -g
hexo g -d

提示输入ssh设置的密码,输入密码即可发布成功
在这里插入图片描述

  • 进入GitHub仓库github.com/yourname/yourname.github.io,此时仓库中已有上传的静态文件
    在这里插入图片描述

  • 点击右侧Settings,在GitHub Pages项选择Source为master branch,点击Save,页面刷新后则已生成个人博客页面,点击链接即可查看
    在这里插入图片描述

七、上传博客源文件

上传博客源文件的目的是为了多地开发。比如你在家里创建了hexo博客,将生成的静态文件上传到GitHub,但你在公司也想写博客,最方便的方式就是用GitHub管理博客的源文件,这样在公司的电脑将博客项目克隆下来,再进行相应配置,便可进行博客的编写。现在将博客源文件发布到BlogSource仓库。

  • 打开博客根目录,将.git文件夹删除
  • 如下编辑.gitignore文件
.DS_Store
Thumbs.db
db.json
*.log
node_modules/
public/
.deploy*/
themes/

这样在上传源文件时就会忽略掉node依赖模块、生成的public静态文件、themes下的主题库等不需要上传的文件

  • 打开Git Bash,创建一个空的git项目
git init
  • 输入命令将所有有改动的文件加入git缓冲区,因为是第一次发布,等于加入全部需要上传的文件
git add .
  • 查看git缓冲区文件状态,或查看简化信息
git status
git status -s
  • 第一次上传执行以下命令,git会将此仓库地址设置成默认的地址
git remote add origin git@github.com:yourname/BlogSource.git

在.git/config文件里可以修改默认仓库地址

[remote "origin"]
	url = http://github.com/yourname/BlogSource
	fetch = +refs/heads/*:refs/remotes/origin/*
  • 提交git更改,m参数填写更新原因,如为空会失败
git commit -m "..."
  • 推送更改。则成功将博客源文件上传至BlogSource仓库。
git push origin

在这里插入图片描述

著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者: 你很德布罗意
邮箱: namidame@sina.cn
博客地址: https://www.namidame.tech/
原文地址: http://www.namidame.tech/Hexo+GitHub_build_blog.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值