免费构建个人博客:Hexo + GitHub + Cloudflare

 转自

免费构建个人博客:Hexo + GitHub + Cloudflare

0. 前置准备

  • US.KG: 用于注册免费域名。
  • Cloudflare: 用于域名解析和加速。
  • Node.js: 用于运行 Hexo。
  • Git: 用于版本控制和部署。
  • GitHub: 用于代码托管和静态站点部署。

一、注册域名

1. 注册 US.KG 帐号

打开 US.KG 注册帐号,电话地址等信息可以使用 身份生成器

2. KYC 验证

重新登录 US.KG,选择 Github KYC 选项,然后点击 Proceed to GitHub。

在最下方填入以下信息,包括 us.kg 的用户名以及注册该网站的原因:

  • Username: XXX
  • Reason for Registering the .US.KG Domain Name (Why): Study and build website.

勾选五个方框,然后点击 Proceed to GitHub。

在仓库主页 FreeDomain 上给一个 Star。

3. 创建域名

登录 US.KG,我们可以创建三个域名,点击 Domain Registration 创建域名。

输入域名前缀,点击 Check。

显示可以创建。

4. Cloudflare 绑定域名

登录 Cloudflare,点击右上角 添加站点,输入在 us.kg 注册的域名。

套餐选择免费的,点击继续。

点击继续前往激活。

将 Cloudflare 提供的服务器地址复制到 us.kg。

点击 Register。

这样就完成了 us.kg 的域名设置。

回到 Cloudflare ,点击继续。

刷新一下,显示如下即表示成功。

二、安装 Hexo

1. 安装 Node.js

下载 Node.js,安装时除了修改安装目录为 D 盘,其余步骤都点击下一步。

安装完成后,使用 Win + R 输入 CMD 打开命令行,输入 node -v,如果出现版本号,则说明安装成功。

将 npm 源修改为阿里云镜像源,在 CMD 窗口运行以下命令:

npm install -g cnpm --registry=https://registry.npmmirror.com

2. 安装 Git

下载 Git,安装时除了修改安装目录为 D 盘,其余步骤都点击下一步。

  • Git CMD 是 Windows 命令行风格。
  • Git Bash 是 Linux 系统命令行风格(推荐使用)。
  • Git GUI 是图形化界面(不建议新手使用)。
git config -l # 查看所有配置 git config --system --list # 查看系统配置 git config --global --list # 查看用户(全局)配置

3. 使用 SSH 连接 GitHub

打开 Git Bash。

配置用户名和邮箱,用户名为 GitHub 账号,邮箱为注册 GitHub 的邮箱。

git config --global user.name "用户名" git config --global user.email "邮箱"

使用 git config -l 检查是否配置成功。

配置公钥 GitHub,执行以下命令生成 SSH 公钥,用于计算机连接 GitHub。

ssh-keygen -t rsa -C "邮箱"

在提示 Enter file in which to save the key 时,直接一路回车即可,不推荐设置密钥。

使用 Everything 搜索 id_rsa.pub 并打开路径。

id_rsa.pub 就是公钥,用记事本打开并复制内容,然后在 GitHub 中找到 Settings - SSH and GPG keys 配置 SSH 密钥。

名字随便填一个。

测试连接,输入以下命令:

ssh -T git@github.com

提示 Are you sure you want to continue connecting (yes/no/[fingerprint])?,输入 yes 即可。

出现 You've successfully 则表示成功,完成了环境准备工作。

4. 创建 GitHub 仓库

打开 GitHub,点击右上角的 + 号,选择 New repository,创建一个 <用户名>.github.io 的仓库。

仓库名字的格式必须为:<用户名>.github.io,可见性选择 public,方便第一次部署检查问题,点击 Create repository 进行创建。

5. 初始化 Hexo 博客

创建一个文件夹保存博客源码,这里选的路径为 D:/Hexo-Blog,在文件夹内右键鼠标,选择 Open Git Bash here

在 Git BASH 输入以下命令安装 Hexo:

npm install -g hexo-cli && hexo -v

完成安装后,输入 hexo -v 验证是否成功。

初始化 Hexo 项目并安装相关依赖:

hexo init blog-demo cd blog-demo npm i

初始化后,D 盘博客文件夹下会出现以下文件:

  • node_modules:依赖包
  • scaffolds:生成文章的一些模板
  • source:用来存放文章
  • themes:主题
  • .npmignore:发布时忽略的文件(可忽略)
  • _config.landscape.yml:主题的配置文件
  • _config.yml:博客的配置文件
  • package.json:项目名称、描述、版本、运行和开发等信息

输入 hexo cl && hexo s 启动项目。

打开浏览器,输入地址:http://localhost:4000/,看到以下效果,说明构建成功了。

6. 将静态博客挂载到 Github Pages

修改 _config.yml 文件,在 Blog-demo 目录下的 _config.yml,这是 Hexo 框架的配置文件,可以修改大部分配置,可参考官方wiki

修改最后一行的配置,将 repository 修改为自己的 GitHub 项目地址,branch 要改为 main 代表主分支(注意缩进)。

deploy: type: git repository: git@github.com:你的用户名/你的用户名.github.io.git branch: main

安装 hexo-deployer-git:

npm install hexo-deployer-git --save

部署到 GitHub,输入命令:

hexo clean && hexo generate && hexo deploy

如果出现 Deploy done,则说明部署成功了。

  • hexo clean:删除之前生成的文件,可以用 hexo cl 缩写。
  • hexo generate:生成静态文章,可以用 hexo g 缩写。
  • hexo deploy:部署文章,可以用 hexo d 缩写。

稍等两分钟,打开浏览器访问:https://<用户名>.github.io/,就可以看到博客内容了。

7. 配置 Cloudflare Pages

打开 Cloudflare,在 Workers 和 Pages 中选择 创建项目

选择 Pages 的 连接到 Git

保存并部署。

点击继续处理项目,在 Cloudflare 中,自定义域粘贴我们注册的 us.kg 复制的域名。

稍等一会。

这样域名就绑定了。

把 GitHub 中的仓库设置为私有仓库,点击 Settings

在最下面找到 Danger Zone

三、安装博客主题安知鱼

1. 安装博客主题

打开 VS Code,选择 文件 - 打开文件夹

在终端输入命令:

git clone -b main https://github.com/anzhiyu-c/hexo-theme-anzhiyu.git themes/anzhiyu

2. 应用主题

修改 Hexo 的配置文件 _config.yml,将主题修改为 anzhiyu

安装 pug 和 stylus 渲染插件,在 VS Code 终端输入命令:

npm install hexo-renderer-pug hexo-renderer-stylus --save --registry=http://registry.npmmirror.com

3. 覆盖主题配置

将 /themes/anzhiyu/_config.yml 文件复制到 hexo 根目录,并重命名为 _config.anzhiyu.yml。以后修改任何主题配置,都只需修改 _config.anzhiyu.yml 的配置即可。

注意:

  • _config.anzhiyu.yml 中的配置优先级最高,修改原 _config.yml 无效。
  • 每次更新主题,可能存在配置变更,请注意更新说明,可能需要手动对 _config.anzhiyu.yml 同步修改。
  • 可以使用 hexo g --debug 查看命令行输出,确认配置是否生效。
  • 如果想将某些配置覆盖为空,注意不要把主键删掉。

4. 本地启动 Hexo

# 本地预览 hexo cl; hexo g; hexo s # 推送更新上线 hexo cl; hexo g; hexo d

5. Hexo 常用命令

以下是 Hexo 博客常用命令:

命令描述
hexo new [layout] <title>创建一篇新的文章
hexo generate 或 hexo g生成静态文件
hexo server 或 hexo s启动本地服务器
hexo deploy 或 hexo d部署网站
hexo clean清除缓存文件和已生成的静态文件
hexo clean; hexo server清除缓存并启动本地服务器查看最新效果
hexo clean; hexo generate; hexo deploy清除缓存后生成新文件并把内容发布到自己的服务器

四、安知鱼主题设置

一、样式设置

1. nav 相关设置

修改 _config.anzhiyu.yml 中的代码:

nav: enable: true # 设置为true travelling: false clock: false menu: - title: 网页 item: - name: GitHub link: https://github.com/pythonahy6 icon: https://pic.imgdb.cn/item/67574d30d0e0a243d4e0bd1a.jpg - name: AI link: https://free.share-ai.top/ icon: https://pic.imgdb.cn/item/6757f02ed0e0a243d4e0fc7c.png - title: 项目 item: - name: 图床 link: https://tgstate.ikun123.com/ icon: https://picgo-1.pages.dev//favicon.ico

2. 博客名称设置

修改 _config.yml 中tltle 和 subtitle 顺便把 language 为中文 zh-CN

# Site title: 观形物语 subtitle: 欢迎来到我的博客,希望你在这里能有收获 description: '' keywords: author: Pythonahy language: zh-CN timezone: ''

3. 菜单栏设置

3.1 文章
menu: 文章: 文章: /archives/ || anzhiyu-icon-box-archive 分类: /categories/ || anzhiyu-icon-shapes 标签: /tags/ || anzhiyu-icon-tags
  • 3.1.1 分类页设置

在 Hexo 博客根目录下打开终端,输入:

hexo new page categories

找到 source/categories/index.md 这个文件,修改添加 type: "categories"

--- title: categories top_img: false #是否显示顶部图 date: 2024-12-10 16:26:39 type: "categories" #页面类型,必须为 tags comments: false #是否显示评论 aside: false #是否显示右侧作者栏 ---

  • 3.1.2 标签页设置

在 Hexo 博客根目录下打开终端,输入下面的命令生成标签页:

hexo new page tags

找到 source/tags/index.md 这个文件,修改添加 type: "tags"

--- title: tags date: 2024-12-10 16:34:02 type: "tags" comments: false aside: false top_img: false ---

3.2 友链

_config.anzhiyu.yml,只设置友人帐:

menu: 文章: 文章: /archives/ || anzhiyu-icon-box-archive 分类: /categories/ || anzhiyu-icon-shapes 标签: /tags/ || anzhiyu-icon-tags 友链: 友人帐: /link/ || anzhiyu-icon-link #朋友圈: /fcircle/ || anzhiyu-icon-artstation #留言板: /comments/ || anzhiyu-icon-envelope
  • 3.2.1 友人帐

在 Hexo 博客根目录下打开终端,输入:

hexo new page link

找到 source/link/index.md 这个文件:

--- title: link top_img: false #是否显示顶部图 date: 2024-12-10 16:45:58 type: "link" comments: false aside: false ---

新建文件 source/_data/link.yml,如果没有 _data 文件夹,请自己新建。在 source/_data/link.yml 中输入:

- class_name: 框架 flink_style: flexcard hundredSuffix: "" link_list: - name: anzhiyu主题 link: https://blog.anheyu.com/ avatar: https://npm.elemecdn.com/anzhiyu-blog-static@1.0.4/img/avatar.jpg descr: 生活明朗,万物可爱 siteshot: https://npm.elemecdn.com/anzhiyu-theme-static@1.1.6/img/blog.anheyu.com.jpg - class_name: 推荐博客 flink_style: telescopic hundredSuffix: "" link_list: - name: 亲自巡山的大王 link: https://dodopoi.github.io/ avatar: https://avatars.githubusercontent.com/u/118941122?v=4 descr: 夕晴照雪霁无瑕 siteshot: https://npm.elemecdn.com/anzhiyu-theme-static@1.1.6/img/blog.anheyu.com.jpg color: vip tag: 技术

4. 搜索设置

安装插件 hexo-generator-search,并根据它的文档进行配置:

npm install hexo-generator-search --save

打开 _config.anzhiyu.yml,搜索 Local search,把 enable 的值改为 true

设置主题配置文件:

local_search: enable: true preload: false CDN:
参数解释
enable是否开启本地搜索
preload预加载,开启后,进入网页后会自动加载搜索文件。关闭时,只有点击搜索按钮后,才会加载搜索文件
CDN搜索文件的 CDN 地址(默认使用的本地链接)

5. 首页顶部设置

# 首页随便逛逛people模式 而非技能点模式,关闭后为技能点模式需要配置creativity.yml peoplecanvas: enable: false img: https://upload-bbs.miyoushe.com/upload/2023/09/03/125766904/ee23df8517f3c3e3efc4145658269c06_5714860933110284659.png
# 首页顶部相关配置 home_top: enable: true # 开关 timemode: date #date/updated title: 在纷繁中见本质 subTitle: 于平凡处觅真知 siteText: designai.us.kg

创建 /source/_data/creativity.yml,输入以下内容:

- class_name: 开启创造力 creativity_list: - name: Docker color: "#57b6e6" icon: https://bu.dusays.com/2023/04/09/643293b0f0abe.png - name: Photoshop color: "#4082c3" icon: https://bu.dusays.com/2022/12/15/639aa3a5c240e.png - name: Node color: "#333" icon: https://npm.elemecdn.com/anzhiyu-blog@2.1.1/img/svg/node-logo.svg - name: Python color: "#fff" icon: https://bu.dusays.com/2023/04/09/643293b1230f7.png - name: JS color: "#f7cb4f" icon: https://bu.dusays.com/2023/04/09/643293b121f02.png - name: Git color: "#df5b40" icon: https://bu.dusays.com/2023/04/09/643293b10ccdd.webp

6. 首页顶部设置

# 首页顶部相关配置 home_top: enable: true # 开关 timemode: date #date/updated title: 在纷繁中见本质 subTitle: 于平凡处觅真知 siteText: designai.us.kg category: - name: 设计 path: /design/ shadow: var(--anzhiyu-shadow-blue) class: blue icon: anzhiyu-icon-dove - name: AI path: // shadow: var(--anzhiyu-shadow-red) class: green icon: anzhiyu-icon-fire - name: Python path: /Python/ shadow: var(--anzhiyu-shadow-green) class: red icon: anzhiyu-icon-book

7. 非轮播显示

配置 _config.anzhiyu.yml

swiper: enable: false swiper_css: https://npm.elemecdn.com/anzhiyu-theme-static@1.0.0/swiper/swiper.min.css #swiper css依赖 swiper_js: https://npm.elemecdn.com/anzhiyu-theme-static@1.0.0/swiper/swiper.min.js #swiper js依赖 banner: tips: xxx title: xxx image: https://xxx.jpg link: https://hxxx.com
tips、title、image、link 自己填

8. 侧边栏设置

# aside (侧边栏) # -------------------------------------- aside: enable: true hide: false button: true mobile: true # display on mobile position: right # left or right display: # 控制对应详情页面是否显示侧边栏 archive: true tag: true category: true card_author: enable: true description: xxx # <div style="line-height:1.38;margin:0.6rem 0;text-align:justify;color:rgba(255, 255, 255, 0.8);">这有关于<b style="color:#fff">产品、设计、开发</b>相关的问题和看法,还有<b style="color:#fff">文章翻译</b>和<b style="color:#fff">分享</b>。</div><div style="line-height:1.38;margin:0.6rem 0;text-align:justify;color:rgba(255, 255, 255, 0.8);">相信你可以在这里找到对你有用的<b style="color:#fff">知识</b>和<b style="color:#fff">教程</b>。</div> # 默认为站点描述 name_link: /

description 这里把 xxx 换成自己要说的话

社交链接:

# 要加社交帐号则自己添加 # social settings (社交图标设置) # formal: # name: link || icon social: Github: https://github.com/dodopoi || anzhiyu-icon-github BiliBili: https://space.bilibili.com/37696304 || anzhiyu-icon-bilibili

侧边个人资料图像:

# Image (图片设置) # -------------------------------------- # Favicon(网站图标) favicon: /favicon.ico # Avatar (头像) avatar: img: https://pic.imgdb.cn/item/675827bed0e0a243d4e1780a.jpg effect: false

二、其它设置

1. 配置文章模板

在 /scaffolds 目录下有几个模板文件,其中:

  • post.md:新建文章模板
  • page.md:新建标签页模板
1.1 post.md 模板,仅供参考
--- title: {{ title }} #【必需】页面标题 date: {{ date }} #【必需】页面创建日期 updated: #【可选】页面更新日期 tags: #【可选】文章标签 categories: #【可选】文章分类 cover: https://pic.imgdb.cn/item/675827bed0e0a243d4e1780a.jpg #【可选】文章缩略图(如果没有设置 top_img,文章页顶部将显示缩略图,可设为 false/图片地址/留空) password: #密码,需要安装插件 hexo-blog-encrypt top: # 1 置顶 keywords: #【可选】文章关键字 description: #【可选】文章描述 top_img: #【可选】文章顶部图片 comments: #【可选】显示文章评论模块(默认 true) toc: #【可选】显示文章 TOC(默认为设置中 toc 的 enable 配置) toc_number: #【可选】显示 toc_number(默认为设置中 toc 的 number 配置) toc_style_simple: #【可选】显示 toc 简洁模式 copyright: #【可选】显示文章版权模块(默认为设置中 post_copyright 的 enable 配置) copyright_author: #【可选】文章版权模块的文章作者 copyright_author_href: #【可选】文章版权模块的文章作者链接 copyright_url: #【可选】文章版权模块的文章作者链接 copyright_info: #【可选】文章版权模块的版权声明文字 mathjax: #【可选】显示 mathjax(当设置 mathjax 的 per_page: false 时,才需要配置,默认 false) katex: #【可选】显示 katex(当设置 katex 的 per_page: false 时,才需要配置,默认 false) aplayer: #【可选】在需要的页面加载 aplayer 的 js 和 css,请参考文章下面的音乐 配置 highlight_shrink: #【可选】配置代码框是否展开(true/false)(默认为设置中 highlight_shrink 的配置) aside: #【可选】显示侧边栏 (默认 true) swiper_index: 10 #【可选】首页轮播图配置 index 索引,数字越小越靠前 top_group_index: 10 #【可选】首页右侧卡片组配置, 数字越小越靠前 ai: #【可选】文章ai摘要 background: "#fff" #【可选】文章主色,必须是16进制颜色且有6位,不可缩减,例如#ffffff 不可写成#fff --- <div class="video-container"> [up主专用,视频内嵌代码贴在这] </div> <style> .video-container { position: relative; width: 100%; padding-top: 56.25%; /* 16:9 aspect ratio (height/width = 9/16 * 100%) */ } .video-container iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } </style>
1.2 page.md 模板,仅供参考
--- title: {{ title }} #【必需】页面标题 date: {{ date }} #【必需】页面创建日期 type: #【必需】标签、分类、关于、音乐馆、友情链接、相册、相册详情、朋友圈、即刻页面需要配置 updated: #【可选】页面更新日期 comments: #【可选】显示页面评论模块(默认 true) description: #【可选】页面描述 keywords: #【可选】页面关键字 top_img: https://img.090227.xyz/file/ae62475a131f3734a201c.png #【可选】页面顶部图片 mathjax: #【可选】显示 mathjax(当设置 mathjax 的 per_page: false 时,才需要配置,默认 false) katex: #【可选】显示 katex(当设置 katex 的 per_page: false 时,才需要配置,默认 false) aside: #【可选】显示侧边栏 (默认 true) aplayer: #【可选】在需要的页面加载 aplayer 的 js 和 css,请参考文章下面的音乐 配置 highlight_shrink: #【可选】配置代码框是否展开(true/false)(默认为设置中 highlight_shrink 的配置) top_single_background: #【可选】部分页面的顶部模块背景图片 ---

2. 文章设置置顶

配置置顶参数 top

如果存在多个置顶文章,top 后的参数越大,越靠前:

3. 给文章设定密码

先安装 hexo-blog-encrypt

npm install --save hexo-blog-encrypt

不需要将 password: 密码 添加到文章开头,在前面的自定义 post.md:新建文章模板中已经内置了,在需要的时候,设置 password 的值就行。

4. 字数统计

先安装插件:

npm install hexo-wordcount --save

将下面的 enable 修改为 true

# wordcount (字数统计) # see https://blog.anheyu.com/posts/c27d.html#字数统计 wordcount: enable: true post_wordcount: true min2read: true total_wordcount: true

地点显示日本修改 location 即可,把 expand 设置为 true,会展开全部目录。

# toc (目录) toc: post: true page: false number: true expand: true #目录展开所有级别 style_simple: false # for post post_copyright: enable: true decode: false author_href: location: 日本 license: CC BY-NC-SA 4.0 license_url: https://creativecommons.org/licenses/by-nc-sa/4.0/ avatarSinks: false # hover时头像下沉 copyright_author_img_back: copyright_author_img_front: copyright_author_link: /

5. 添加 RSS 订阅支持

npm install hexo-generator-feed --save

在 _config.yml 文件中配置:

# Site title: Pythonahy subtitle: ‘欢迎来到我的博客,希望你在这里能有收获' description: '' keywords: author: Pythonahy language: zh-CN timezone: '' # URL ## Set your site url here. For example, if you use GitHub Page, set url as 'https://username.github.io/project' url: https://xxx # 修改为你的实际网站地址

再配置 _config.anzhiyu.yml

# social settings (社交图标设置) # formal: # name: link || icon social: rss: https://designai.us.kg/atom.xml || anzhiyu-icon-rss # Github: https://github.com/anzhiyu-c || anzhiyu-icon-github # BiliBili: https://space.bilibili.com/372204786 || anzhiyu-icon-bilibili feed: enable: true type: atom path: atom.xml limit: 20 hub: content: true # 建议设为 true,这样订阅者可以看到完整内容 content_limit: 140 content_limit_delim: ' ' order_by: -date icon: icon.png autodiscovery: true

6. 博客永久链接设置

安装 hexo-abbrlink 插件:

npm install hexo-abbrlink --save

配置 _config.yml 中的内容:

# # URL # ## Set your site url here. For example, if you use GitHub Page, set url as 'https://username.github.io/project' url: https://designai.us.kg # 修改为你的实际网站地址 permalink: posts/:abbrlink.html abbrlink: alg: crc32 rep: hex permalink_defaults: pretty_urls: trailing_index: false # Set to false to remove trailing 'index.html' from permalinks trailing_html: true # Set to false to remove trailing '.html' from permalinks

7. 添加音乐

修改 _config.anzhiyu.yml:其它默认,修改 id 为自己网易音乐的

# 左下角音乐配置项 # https://github.com/metowolf/MetingJS nav_music: enable: true console_widescreen_music: false # 宽屏状态控制台显示音乐而不是标签 enable为true 控制台依然会显示 id: 517301810 theme: '#42b983' server: netease fixed: true # 开启吸底模式 autoplay: true # 是否自动播放 loop: 'all' # 音频循环播放, 可选值: 'all', 'one', 'none' order: 'random' # 音频循环顺序, 可选值: 'list', 'random' preload: 'auto' # 预加载,可选值: 'none', 'metadata', 'auto' volume: 0.7 # 默认音量,请注意播放器会记忆用户设置,用户手动设置音量后默认音量即失效 listFolded: true # 列表默认折叠 hideLrc: true # 隐藏歌词 listMaxHeight: "525px" #列表最大高度 # 路径为 /music 的音乐页面默认加载的歌单 1. nav_music 2. custom music_page_default: nav_music

8. 添加豆瓣看书电影到博客

1. 先安装插件 hexo-douban
npm install hexo-douban --save
2. 配置文件

打开 _config.yml 只要修改 id,其它默认:

douban: id: 285338112 builtin: true dynamic: true item_per_page: 10 meta_max_line: 4 customize_layout: page swup: false book: path: books/index.html title: "无为书斋" quote: "书在几上,道在心中" actions: - do - wish - collect option: movie: path: movies/index.html title: "坐忘影室" quote: "万象皆为虚幻,悟道方见真常" actions: - do - wish - collect option: # game: # path: games/index.html # title: "This is my game title" # quote: "This is my game quote" # actions: # - do # - wish # - collect # option: # song: # path: songs/index.html # title: "This is my song title" # quote: "This is my song quote" # actions: # - do # - wish # - collect # option:
3. 生成豆瓣页面
hexo douban

不知道为什么,获取的电影太慢

4. 配置生成目录

打开 _config.anzhiyu.yml,会在主题文件夹下的 public 目录生成一个 books 和 movies 文件夹。

menu: 文章: 文章: /archives/ || anzhiyu-icon-box-archive 分类: /categories/ || anzhiyu-icon-shapes 标签: /tags/ || anzhiyu-icon-tags 友链: 友人帐: /link/ || anzhiyu-icon-link #朋友圈: /fcircle/ || anzhiyu-icon-artstation #留言板: /comments/ || anzhiyu-icon-envelope 书影: 阅读: /books/ || anzhiyu-icon-book-open 电影: /movies/ || anzhiyu-icon-play

上面的自定义图标:

阅读: /books/ || anzhiyu-icon-book-open 电影: /movies/ || anzhiyu-icon-play

安知鱼支持修改图标,打开 anzhiyu 主题图标,使用 anzhiyu-icon- + 图标的名字,比如 anzhiyu-icon-play

9. 添加烟火特效

enable 设置为 true 即可:

fireworks: enable: true zIndex: 9999 # -1 or 9999 mobile: false

10. 配置 Twikoo 评论系统

1. 申请 MongoDB 账号

进邮箱验证激活账号。

填写问卷调查。

选择免费套餐,云服务商选择 aws,地区选择 N. Virginia (us-east-1)。

接下来会得到一个用户名和密码,先复制一份保存,等下会用到。

在 Database Access 页面点击 Add New Database User 创建数据库用户。

Authentication Method 选 Password,在 Password Authentication 下设置数据库用户名,点击 Autogenerate Secure Password 生成密码并复制密码。

选择 Atlas Admin,最后点击 Add User。

在 Network Access 页面点击 Add IP Address,点击 ALLOW ACCESS FROM ANYWHERE,点击 Confirm。

  1. 在 Database 页面点击 Connect,连接方式选择 Drivers。

复制如下数据库连接字符串,将连接字符串中的 <username>:<password> 修改为刚刚创建的数据库 用户名:密码,<> 不要保留。

2. Vercel 部署

打开 Vercel 注册账号,用 GitHub 登录。

点击 一键部署,填入项目名字,点击 Create。

点击 Continue to Dashboard。

点击设置。

点击 Domains,设置自定义域名。

不绑定自己的域名,会出现评论不显示,或者用不了的情况,所以需要绑定我们自己的域名。

输入自己的域名,复制下面的信息。

打开 Cloudflare 选择自己的服务器,点击,dns,记录。

在 Domains 中,出现打勾就行。

配置环境变量并调试配置,找到 Environment Variables,添加环境变量 MONGODB_URI,值为前面记录的数据库连接字符串。

找到 Deployment Protection,设置 Vercel Authentication 为 Disabled,然后点击 Save

找到 Function,将 Function Region 修改为你需要的地区。

重新部署应用,点击 Deployments,点击三个点,点击 Redeploy

勾选 Use existing Build Cache 然后点击下面的 Redeploy

出现这个表示成功了。

接下来就是配置 _config.anzhiyu.yml,搜索 Twikoo:

comments: # Up to two comments system, the first will be shown as default # Choose: Valine/Waline/Twikoo/Artalk use: Twikoo text: true # Display the comment name next to the button # lazyload: The comment system will be load when comment element enters the browser's viewport. # If you set it to true, the comment count will be invalid lazyload: true count: false # Display comment count in post's top_img card_post_count: false # Display comment count in Home Page

修改:use: Twikoolazyload: true

再修改下面这里,重新部署即可:

# Twikoo # https://github.com/imaegoo/twikoo twikoo: envId: https:xxxxxx/ # 自己自定义的域名 region: visitor: false option:

运行命令:

hexo clean; hexo generate; hexo deploy

效果:

五、参考教程

張貼留言

較新的 較舊