本地 Hexo

  1. 安装 Node.js
  2. 安装 Git
  3. 在本地新建文件夹 blog_hexo
1
2
3
4
5
6
cd D:\blog_hexo>
npm install hexo-cli -g
hexo init
npm install hexo-deployer-git --save
git clone -b master https://github.com/jerryc127/hexo-theme-butterfly.git themes/butterfly
npm install hexo-renderer-pug hexo-renderer-stylus --save
  1. 修改_config.yml 文件,将 theme: landscape 修改成 theme: butterfly
  2. 关于在左上角开启主页/分类/标签功能,请查阅 分类/Tags 显示 404 问题
  3. 在本地预览
1
2
3
hexo cl
hexo g
hexo s

Hexo+Github Page

  1. 在 Github 网页新建同名仓库 xie-dd.github.io
  2. 修改 D:\blog_hexo_config.yml
1
2
3
4
deploy:
type: git
repo: https://github.com/xie-dd/xie-dd.github.io.git
branch: master
  1. 部署到远程
1
hexo g -d

注意:hexo g -d 会将 public 目录中的文件和目录推送至 _config.yml 中指定的远端仓库和分支中,并且完全覆盖该分支下的已有内容

  1. 远程最终是这样的:

  1. 网页访问 https://xie-dd.github.io/ 即可

Hexo+Github Page+Github Action

接着上面的 blog_hexo 文件夹操作

参考:使用 Hexo 和 Github Actions 自动化博客更新-bilibili

  1. 访问 Github—头像(右上角)—Settings—Developer Settings—Personal access tokens—generate new token—创建的 Token 的名称随意,但必须勾选 repo 项 和 workflows 项—复制 Token
  2. 在 Github 创建用于存放博客所有文件的 **私有仓库 **blog_hexo_repo (必须是私有仓库,因为 Token 的问题我没解决掉
  3. 点击仓库 Setting—Sectets and variables—Actions—New repository secret—Name:DEPLOY_BLOG—Secrets:粘贴第 1 步复制的 Token
  4. 在本地 blog_hexo 文件夹创建新文件夹.github,在.github文件夹内新建 main.yml 文件
  5. 在 main.yml 文件粘贴下面内容:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
name: Deploy Hexo Blog

on:
push:
branches: [master]

jobs:
bulid:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2

- name: Setup Node.js environment
uses: actions/[email protected]
with:
node-version: 18.12.1

- name: Deploy Blog
env:
DEPLOY_BLOG: ${{secrets.DEPLOY_BLOG}}
run: |
git config --global user.name "xie-dd"
git config --global user.email "[email protected]"
npm install
npm run build
npm run deploy

  1. 修改 D:\blog_hexo_config.yml 文件,将
1
2
3
4
deploy:
type: git
repo: https://github.com/xie-dd/xie-dd.github.io.git
branch: master

修改为:

1
2
3
4
5
6
7
deploy:
type: git
repo:
github:
url: https://github.com/xie-dd/xie-dd.github.io.git
branch: master
token: 这里填写你的Token, 正是因为这里要填写Token,所以blog_hexo_repo仓库不能公开
  1. 在本地 blog_hexo 文件夹将代码推送到远程
1
2
3
4
5
6
git init
git remote add origin https://github.com/xie-dd/blog_hexo_repo.git
git checkout -b master
git add .
git commit -m "github action update"
git push origin master
  1. git 上传结束后会触发 Github Action, 然后会自动部署内容到博客页面

Hexo+Github Page+Github Action+语雀

几个注意事项

  1. 语雀拉取文章有延迟,需要注意
  2. 这里实际有两种情境
    1. 第 1 种,先在本地命令行执行 yuque-hexo sync,再 git 推送到远程。这样即部署到了博客页面,也把语雀文章备份到本地以及 Github 仓库了
    2. 第 2 种,不在本地命令行执行 yuque-hexo sync,直接在本地 git 推送到远程。这样会在 Github Action 中拉取语雀内容并部署到博客页面,但是语雀内容不会备份到本地,也不会备份到 github 仓库

配置流程

Hexo:语雀云端写作 Github Actions 持续集成

  1. 获取语雀 Token
  2. 获取语雀用户名与语雀知识库短链接
  3. 语雀上写一篇文章并发布,文章内容格式如下,注意不要渲染三个短横线
1
2
3
4
5
6
---
title: Hexo+Github Page+Github Action
tags: [test]
---

content
  1. 网页 Github 仓库 blog_hexo_repo—Setting—Sectets and variables—Actions—New repository secret—Name:YUQUE_TOKEN—Secrets:粘贴语雀的 Token
  2. 在本地安装 npm i -g yuque-hexo
  3. 修改文件 D:\blog_hexo\package.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
{
"name": "hexo-site",
"version": "0.0.0",
"private": true,
"scripts": {
"start": "yuque-hexo clean && yuque-hexo sync && hexo clean && hexo generate",
"build": "hexo generate",
"clean": "hexo clean",
"deploy": "hexo deploy",
"server": "hexo server",
"sync": "yuque-hexo sync",
"clean:yuque": "yuque-hexo clean"
},
"yuqueConfig": {
"postPath": "source/_posts",
"cachePath": "yuque.json",
"mdNameFormat": "title",
"adapter": "markdown",
"concurrency": 5,
"baseUrl": "https://www.yuque.com/api/v2",
"login": "xdd1997",
"repo": "blog",
"token": "粘贴你的语雀token",
"onlyPublished": true,
"onlyPublic": true
},
"hexo": {
"version": "6.3.0"
},
"dependencies": {
"hexo": "^6.0.0",
"hexo-deployer-git": "^4.0.0",
"hexo-generator-archive": "^2.0.0",
"hexo-generator-category": "^2.0.0",
"hexo-generator-index": "^3.0.0",
"hexo-generator-tag": "^2.0.0",
"hexo-renderer-ejs": "^2.0.0",
"hexo-renderer-marked": "^6.0.0",
"hexo-renderer-pug": "^3.0.0",
"hexo-renderer-stylus": "^3.0.0",
"hexo-server": "^3.0.0",
"hexo-theme-landscape": "^1.0.0"
}
}
  1. 修改文件 D:\blog_hexo.github\workflows\main.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
name: Deploy Hexo Blog

on:
push:
branches: [master]

jobs:
bulid:
runs-on: ubuntu-latest
steps:

- name: Checkout Repository master branch
uses: actions/checkout@master

- name: 设置 Node 环境
uses: actions/[email protected]
with:
node-version: 18.12.1

- name: 设置 Hexo 依赖项并生成 Public 文件.
env:
YUQUE_TOKEN: ${{ secrets.YUQUE_TOKEN }}
run: |
npm install hexo-cli -g
npm install yuque-hexo -g
npm install
npm run start

- name: 部署到xie-dd.github.io网站
uses: peaceiris/actions-gh-pages@v3
with:
personal_token: ${{ secrets.DEPLOY_BLOG }}
external_repository: xie-dd/xie-dd.github.io
publish_branch: master
publish_dir: ./public
commit_message: ${{ github.event.head_commit.message }}

  1. 推送到远程并自动部署博客网页。这里有几种选择:

(1)在本地执行 yuque-hexo sync,然后执行 hexo g -d。这种情况语雀文章会被下载到本地,然后部署到网页,但是不会上传语雀文章到 Github 仓库,自然也不会触发 Github Action

(2)在本地直接执行 git add commit push 三件套,这样会将本地原来的文章上传到 Github,于是触发了 Github Action,然后自动爬取语雀文章,部署到网页。这种情况不会备份语雀文章到本地,也不会备份语雀文章到 Github 仓库

(3)在本地执行 yuque-hexo sync,然后执行 git add commit push 三件套,这样会触发 Github Action,然后自动爬取语雀文章,部署到网页。这种情况会下载语雀文章到本地,也会备份语雀文章到 Github 仓库(推荐)

Hexo+Github Page+Github Action+语雀+云函数

https://19970622.xyz/posts/2046/

Hexo+Github Page+Github Action+语雀+任务计划程序

  1. win+R—taskschd.msc—创建基本任务
  2. 名称:同步语雀文章到 Hexo
  3. 触发器:每天
  4. 操作:启动程序
  5. 程序或脚本:”C:\Python38\python.exe”
  6. 添加参数:”D:\File_Important\yuque_hexo\yuque_hexo.py”, 该文件内容如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59

# @Author: [email protected]
# @CreateData: 2023-10-25
# @MaintenanceDate: 2023-10-27
# @Purpose: python 提交本地文件到 github


import subprocess
import datetime
import time

# 定义要切换到的目录
repo_directory = r"D:\blog_hexo"

# 切换到指定目录
try:
# 使用subprocess运行cd命令切换目录
subprocess.run(f"cd /d {repo_directory} && git status", shell=True, check=True, stdout=subprocess.PIPE)

except subprocess.CalledProcessError as e:
print("切换目录时出现错误:", e)
exit(1)

# 获取当前时间字符串
current_datetime = datetime.datetime.now()
formatted_datetime = current_datetime.strftime("%Y-%m-%d_%H%M%S")

# 写 log文件, 为了可以正常git提交
with open(f"{repo_directory}/log.txt", "w") as fw:
fw.write(formatted_datetime + '\n')

# 执行Git命令(例如:git add, git commit, git push)
try:
# 拉取语雀文章
subprocess.run(f"cd /d {repo_directory} && yuque-hexo sync", shell=True, check=True)

# 处理git可能的异常
subprocess.run(f"git config --global --unset http.proxy", shell=True, check=True)
subprocess.run(f"git config --global --unset https.proxy", shell=True, check=True)
subprocess.run(f"ipconfig/flushdns", shell=True, check=True)

# 添加文件
subprocess.run(f"cd /d {repo_directory} && git add .", shell=True, check=True)

# 提交更改
subprocess.run(f"cd /d {repo_directory} && git commit -m '{formatted_datetime}'", shell=True, check=True)

# 推送到GitHub
subprocess.run(f"cd /d {repo_directory} && git push", shell=True, check=True)

print("成功提交到GitHub")

except subprocess.CalledProcessError as e:
print("=" * 80)
print("执行Git命令时出现错误:", e)
exit(1)

import time
time.sleep(5)

Hexo+Github Page+Github Action+语雀+OSS 部署

https://blog.zhequtao.com/content/op/deploy-fe-with-alioss.html

  1. 安装插件:npm install hexo-deployer-ali-oss –save
  2. 开通阿里云 oss,权限为 公共读
  3. 修改 hexo 博客根目录下的配置文件_config.yml ,修改如下部署配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
deploy:
- type: git
repo:
github:
url: https://github.com/xie-dd/xie-dd.github.io.git
branch: master
token: ghp_sgiscI*****qVgyXNw3kooiek0keA7n

## 部署到阿里云 OSS
- type: ali-oss
region: <您的bucket 地址>
accessKeyId: <您的oss accessKeyId>
accessKeySecret: <您的oss accessKeySecret>
bucket: <您的bucket name>
  1. hexo g -d 即可部署到 OSS
  2. 在 oss 管理界面—数据管理—静态页面
    1. 默认首页: index.html
    2. 子目录首页:开通
    3. 文件 404 规则:Index
    4. 默认 404 页:空着即可
  3. 等待一段时间(真的要等待)才会生效,访问你的 Bucket 域名即可 hexoxdd.oss-cn-beijing.aliyuncs.com

现在的成果

方式 1:

  1. 在语雀写文章
  2. 在本地 cmd 执行下面代码,即可将语雀内容备份到本地与 Github 仓库,并部署到 Github Page
1
2
3
4
5
cd /d M:\blog_hexo
yuque-hexo sync # 这一步是备份到本地,可以不执行,文章更新有延迟
git add .
git commit -m "202310241546"
git push -u origin master

方式 2

  1. 在语雀写文章
  2. 在 cmd 按照下面的方法部署,这样不会备份,也不会触发 Github Action
1
2
3
cd /d M:\blog_hexo
yuque-hexo sync
hexo g -d

方式 3

使用 Windows 任务计划程序自动执行

方式 4

Github 自动部署到 Github Page 与 阿里云 OSS

方式 5

语雀写完文章后点击发布,自动触发云函数,然后触发 github action

可能的错误

fatal: “unable to access” https://github.com/ Recv failure: Connection was reset

解决方法:https://blog.csdn.net/m0_69087087/article/details/128838186

1
2
3
4
5
win+r --- cmd
git config --global --unset http.proxy
git config --global --unset https.proxy
ipconfig/flushdns
git push origin master

网站运行时间显示为 0

不知道我的 _config.butterfly.yml 文件 publish_date 这个地方为什么是 start_date,改回 publish_date 就好了

1
2
3
4
# 运行时间
runtimeshow:
enable: true
publish_date: 2023/10/21 00:00:00

主题设置以及其它问题

图片问题

**方法 1 **

以 butterfly 主题为例,打开主题文件的 /themes/butterfly/layout/includes/head.pug,在 “meta(name=”theme-color” content=themeColor)” 后方添加 meta(name=”referrer” content=”no-referrer”),该步骤是确保语雀中的图片可以正常加载

1
2
meta(name="theme-color" content=themeColor)
meta(name="referrer" content="no-referrer")

方法 2

在语雀中使用图片链接,而不是粘贴图片

1
![](...)

评论系统

Hexo + Butterfly 评论功能

giscus 配置

hexo-butterfly 主题-giscus 评论系统设置 - 知乎

  1. 安装 Giscus:https://github.com/apps/giscus
  2. 配置 Giscus:https://giscus.app/zh-CN,得到一段脚本,类似
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<script src="https://giscus.app/client.js"
data-repo="xie-dd/blog_hexo_comment"
data-repo-id="R_kgDOKg***"
data-category="General"
data-category-id="DIC_kwDOKjyVRs4Car4o***"
data-mapping="url"
data-strict="0"
data-reactions-enabled="1"
data-emit-metadata="0"
data-input-position="top"
data-theme="preferred_color_scheme"
data-lang="zh-CN"
data-loading="lazy"
crossorigin="anonymous"
async>
</script>
  1. 修改主题文件下面两处内容 D:\blog_hexo_config.butterfly.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
comments:
# Choose: Disqus/Disqusjs/Livere/Gitalk/Valine/Waline/Utterances/Facebook Comments/Twikoo/Giscus/Remark42/Artalk
use: Giscus
text: true # Display the comment name next to the button
lazyload: false
count: false # Display comment count in post's top_img
card_post_count: false # Display comment count in Home Page

# Giscus
# https://giscus.app/
giscus:
repo: "xie-dd/blog_hexo_comment"
repo_id: "R_kgDOKjyVRg"
category_id: "DIC_kwDOKjyVRs4Car4o"
theme:
light: light
dark: dark
option:

网页链接问题

在 Hexo 中使用 Hexo-abbrlink 生成唯一文章链接

Hexo 生成博客文章的链接时,默认格式 permalink: :year/:month/:day/:title/ ,如果标题中含中文的话,复制 URL 链接的话中文字符就会是一大串编码字符。如果想为每一篇文章生成唯一 ID 的话,推荐使用 hexo-abbrlink

  1. 在本地安装 npm install hexo-abbrlink -g
  2. 修改本地 config.yml 文件如下,注释原来的,启用新的
1
2
# permalink: :year/:month/:day/:title/
permalink: posts/:abbrlink/
  1. 修改文件 D:\blog_hexo.github\workflows\main.yml,添加一行 npm install hexo-abbrlink -g
1
2
3
4
5
6
7
8
- name: 设置 Hexo 依赖项并生成 Public 文件.
env:
YUQUE_TOKEN: ${{ secrets.YUQUE_TOKEN }}
run: |
npm install hexo-cli -g
npm install hexo-abbrlink -g
npm install yuque-hexo -g

文章最下面作者与链接

修改文件 D:\blog_hexo_config.yml, 里面的 author url 即可

搜索系统

  1. 进入官网地址  注册 — 点击左下角 Data sources 图标—Indices—Creat Index
  2. 点击左下角 Setting 图标—API Keys—All API Keys—New API Key
  3. 在弹窗中:有一个选项选择前面创建的 Index, 最后的 ACL 选择以下 7 项:search,browse,addObject,deleteObject,deletelndex,listlndexes,usage, 其它默认,最后点击 Create
  4. 点击左下角 Setting 图标—API Keys—Your API Keys,获得三个参数 Application ID,Search-Only API Key,Admin API Key
  5. 安装插件  npm install hexo-algoliasearch
  6. 修改 D:\blog_hexo_config.yml ,添加如下代码,记得把###替换
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
# 搜索内容
algolia:
appId: "###"
apiKey: "###"
adminApiKey: "###"
chunkSize: 5000
indexName: "blog_hexo"
fields:
- content:strip:truncate,0,500
- excerpt:strip
- gallery
- permalink
- photos
- slug
- tags
- title
  1. 修改 D:\blog_hexo_config.butterfly.yml
  2. 执行 hexo algolia
1
2
3
4
5
6
7
8
algolia_search:
enable: true
hits:
per_page: 10
labels:
input_placeholder: Search for Posts
hits_empty: "我们没有找到任何搜索结果: ${query}"
hits_stats: "找到${hits}条结果(用时${time} ms)"
  1. 如果使用了 Github Action, 还需要修改 D:\blog_hexo.github\workflows\main.yml
1
2
# 在安装 hexo-cli 的地方添加一行
npm install hexo-algoliasearch -g

Front-matter

1
2
3
4
5
6
7
8
---
title: 标题
categories: [A]
tags: [A, B, C]
date: 2023-10-23
updated: 2023-10-23
cover : 封面头图链接文本
---

cover: 控制主页上每篇文章显示图片,如果不设置,则主页文章没有图片

top_img: 控制文章内最上面图片,如果没有,则使用 cover 的图片

SEO 优化

https://zhuanlan.zhihu.com/p/344927945

百度收录

https://zhuanlan.zhihu.com/p/100922816

  1. 验证时,使用文件验证,下载百度给的 html 文件放到 source 文件夹
  2. 修改刚才的 html 文件,添加下面的前三行
1
2
3
4
---
layout: false
---
cada67d9dde712f908945c31d3ed3451
  1. 其它参照一般的教程即可
  2. 提交收录时选择 sitemap 收录【sitemap 提交工具仅对已验证站点开放使用】,先执行以下命令生成 baidusitemap.xml,部署到 Github Page
1
2
npm install hexo-generator-baidu-sitemap --save
hexo g
  1. 在百度平台—资源提交—普通收录—sitemap, 添加一条
1
https://20161101.xyz/baidusitemap.xml
  1. 实在不行,手动提交,将链接粘贴后,提交
  2. 也可以使用 API 提交,使用使用定时任务执
1
2
cd /d D:\blog_hexo\public
curl -H 'Content-Type:text/plain' --data-binary @baidu_urls.txt "http://data.zz.baidu.com/urls?site=https://20161101.xyz&token=****"

文章排序

希望文章安装更新时间排序,修改文件:D:\blog_hexo_config.yml

1
2
3
4
index_generator:
path: ""
per_page: 10
order_by: -updated

ICP 备案号

打开文件 D:\blog_hexo\themes\butterfly\layout\includes\footer.pug ,添加下面一行

1
2
3
<span> | 豫ICP备<a href="https://beian.miit.gov.cn/" target="_blank">2023031381</a>号</span>

<span> | <img src="https://mypic2016.oss-cn-beijing.aliyuncs.com/picGo/202311231912584.png" height="16" width="16" style="display:inline-block;"> 豫公网安备<a href="https://beian.mps.gov.cn/#/query/webSearch?code=41140002000710\" target="_blank">41140002000710</a>号</span>

主页文章显示数目以及归档页文章显示数目

  • 主页文章显示数目只需在_config.yml 中调整
1
2
3
4
index_generator:
path: ''
per_page: 10
order_by: -updated
  • archive 页面中调整需要下载插件
plain npm install --save hexo-generator-archive

然后在_config.yml 中添加:

plain archive_generator: per_page: 5 yearly: true monthly: true