Hexo SEO 优化的基本套路

Hexo SEO 优化的基本套路

在 2021 年的今天,个人博客已经逐渐式微。博客不仅是自己的一个笔记本,既然将它公开在公共网络,肯定还是希望能让更多人看到吧?

不同于私域流量,我们的网站流量更多的来自于互联网的 🔍 搜索引擎,动态博客有很多成熟且简单的 SEO 优化方式,而像 Hexo 这样的静态博客毕竟还是相对小众,因此本文主要介绍在刚搭建好自己的 Hexo 博客后需要做的一些 SEO 优化步骤及注意事项

修改网站信息

使用文本编辑器打开 Hexo 的配置文件,找到 # Site 部分,根据实际修改网站信息

# Site
title: '网站标题'
subtitle: '网站副标题'
description: "网站描述"
keywords: "网站关键词"
author: '作者名称'
language: '网站语言'      
timezone: '网站时区'

各项参数按照 Hexo 官方文档 说明如下:

参数描述
title网站标题
subtitle网站副标题
description网站描述
keywords网站的关键词,支持多个关键词
author您的名字
language网站使用的语言
timezone网站时区, 参考 时区列表 进行设置

下面是一个网站信息写法示例:

title: "Dejavu's Blog"
subtitle: '与君初相见,犹如故人归'
description: "Dejavu's Blog,Dejavu的博客,Dejavu的日志"
keywords: "Dejavu,博客,dejavu,Blog,Hexo"
author: 'Dejavu'
language: 'zh-CN'
timezone: 'Asia/Shanghai'

优化永久链接

对于域名,个人踩了一些坑,不建议使用 裸域 ,建议使用 子域名,比如:

  • 建议 www.example.comblog.example.com
  • 不建议使用 example.com

👉 对于 Hexo 永久链接格式优化的说明详见另一篇:优化 Hexo 的永久链接

添加网站地图

常用的生成网站地图插件是 Hexo 官方的 hexo-generator-sitemap,推荐使用对 SEO 更加友好的 hexo-generator-seo-friendly-sitemap 插件来生成网站地图:

# 在Hexo根目录打开Terminal/Bash安装插件
$ npm install hexo-generator-seo-friendly-sitemap --save
# 或者使用yarn
$ yarn add hexo-generator-seo-friendly-sitemap

在 Hexo 配置文件里加入插件配置项:

sitemap:
    path: sitemap.xml
    tag: false
    category: false
参数说明
path索引网站地图路径,默认 sitemap.xml
tag网站地图是否排除标签页面
category网站地图是否排除分类页面

建议:设置 tag: falsecategory: false 将标签页面和分类页面排除在网站地图外

以我的为例,按照上面配置后本站的网站地图即为:

😃 将网站地图提交到 谷歌百度必应 等站长平台后台,请注意:

网站地图类型特殊说明
sitemap.xml百度不支持
post-sitemap.xml都支持
page-sitemap.xml都支持

添加 robots.txt

Robots.txt 是存放在网站根目录下的一个纯文本文件,它可以指定搜索引擎蜘蛛只抓取指定的内容,或者是禁止搜索引擎蜘蛛抓取网站的部分或全部内容,在线生成 robots.txt :

然后复制生成的 robots.txt 文件内容,在 Hexo 的 source 目录下新建 robots.txt 文件写入即可,站点部署后使用站长工具校验更新下 robots.txt 即可

nofollow 标签

我们使用 Hexo 官方插件 hexo-filter-nofollow 来给站外链接添加 rel="external nofollow noreferrer" 属性,从而降低 不安全搜索引擎印象不佳 的外链对网站 SEO 的影响,安装插件:

# 在Hexo目录打开Terminal/Bash
$ npm install hexo-filter-nofollow --save
# 或者使用yarn
$ yarn add hexo-filter-nofollow

在 Hexo 的配置文件中增加插件配置项:

nofollow:
  enable: true  #true/false 启用/关闭插件
  field: site   #site/post  处理全站/仅文章链接
  exclude:      #排除域名,同的子域名视为不同的域名
    - 'exclude1.com'
    - 'exclude2.com'

主动推送链接

hexo-submit-urls-to-search-engine 是一个 Hexo 插件,在每次运行 hexo deploy 命令后会主动推送网站更新链接到 谷歌百度必应 站长平台,从而加快搜索引擎收录速度

安装插件

在 Hexo 根目录打开 Terminal/Bash:

$ npm install --save hexo-submit-urls-to-search-engine --save
# 或者使用yarn
$ yarn add hexo-submit-urls-to-search-engine

获取站长平台Token

确保在 谷歌百度必应 等站长平台已经添加了你的网站

百度

进入网站管理,按下图所示找到资源提交接口的 Token 并记录备用

必应

进入网站管理,点击右上角 设置,查看 API 密钥 并记录备用

谷歌

😅 得益于中国大陆互联网的境况,此步骤你可能还需要合适的代理软件

打开 Google Indexing API 的官方文档可以看到 使用 Indexing API 的前提条件,按照该文档完成以下步骤:

注意在 创建服务账号 时以 json 格式保存密钥,点击 创建 会自动下载密钥文件,请妥善保存后面会用到

点击左侧 服务账号,有个 服务帐号电子邮件地址 ,复制并记录备用

进入 Google Search Console——管理用户和权限 后台,按照图示步骤添加用户,电子邮件地址为上一步记录的 服务帐号电子邮件地址

在进入 Google Search Console——旧版网站,点进你添加资源的网站,在 已验证的拥有者 下面的 电子邮件 地址中点击 添加所有者,同样添加上一步的 服务帐号电子邮件地址 并继续

插件配置

编辑 Hexo 的配置文件,添加 hexo-submit-urls-to-search-engine 插件的配置项,以 的配置文件为例(部分数据已脱敏)

# auto-push-urls-to-search-engine
hexo_submit_urls_to_search_engine:
  submit_condition: count #链接被提交的条件,可选值:count | period 现仅支持count
  count: 100 # 提交最新的链接个数
  period: 1000 # 提交修改时间在 1000 秒内的链接
  google: 1 # 是否向Google提交(0:否;1:是)
  bing: 1 # 是否向bing提交(0:否;1:是)
  baidu: 1 # 是否向baidu提交(0:否;1:是)
  txt_path: submit_urls.txt ## 文本文档名, 需要推送的链接会保存在此文本文档里
  baidu_host: https://www.dejavu.moe ## 在百度站长平台中注册的域名
  baidu_token: xxxxxxxxxxx  ## 请注意这是您的秘钥, 所以请不要把它直接发布在公众仓库里!
  bing_host: https://www.dejavu.moe ## 在bing站长平台中注册的域名
  bing_token: xxxxxxxxxxxxxxxxx  ## 请注意这是您的秘钥, 所以请不要把它直接发布在公众仓库里!
  google_host: https://www.dejavu.moe ## 在google站长平台中注册的域名
  google_proxy: http://127.0.0.1:7890 # 向谷歌提交网址所使用的系统 http 代理,填 0 不使用,以Clash为例
  google_key_file: genial-xxxxxx-xxxxxx-xxxxxxxxx.json #Google服务项目的json文件名全称,放于网站根目录(与hexo _config.yml文件位置相同),请不要把json文件内容直接发布在公众仓库里!
  replace: 0  # 是否替换链接中的部分字符串,可选值:1 | 0(0:否;1:是)
  find_what: 
  replace_with:

🤠 记得看后面的注释说明,所需要的参数前面都提到了。需要注意的是 google_proxy 这个配置项,在本地推送 Hexo 更新的话需要代理,如果 Hexo 源代码托管在可以访问 Google 的集成部署平台(如:Travis CI、Vercel、Github Actions…)请将代理配置设为 0,并将部署命令由 hexo generate 改为 hexo generate && hexo deploy

如果按照上述步骤成功的话,那么在执行 hexo deploy 后,会得到类似下面的提示,那么恭喜你,配置完成啦~

INFO  Deploying: cjh_bing_url_submitter
INFO  Deploy done: cjh_bing_url_submitter
INFO  Deploying: cjh_baidu_url_submitter

INFO  Submitting baidu urls
https://www.dejavu.moe/posts/hexo-permalinks/
https://www.dejavu.moe/posts/hexo-seo/
https://www.dejavu.moe/posts/c-note-3/
https://www.dejavu.moe/posts/c-note-2/
https://www.dejavu.moe/posts/c-note-1/
https://www.dejavu.moe/posts/git-npm-yarn-proxy/
https://www.dejavu.moe/posts/hexo-next-beautify/
https://www.dejavu.moe/posts/hello-world/
Baidu response:  {"remain":2992,"success":8}
INFO  Deploy done: cjh_baidu_url_submitter
INFO  Deploying: cjh_google_url_submitter
INFO  Deploy done: cjh_google_url_submitter
INFO  Submitting bing urls

INFO  Bing Submitting: https://www.dejavu.moe/posts/hexo-permalinks/
INFO  Bing Submitting: https://www.dejavu.moe/posts/hexo-seo/
INFO  Bing Submitting: https://www.dejavu.moe/posts/c-note-3/
INFO  Bing Submitting: https://www.dejavu.moe/posts/c-note-2/
INFO  Bing Submitting: https://www.dejavu.moe/posts/c-note-1/
INFO  Bing Submitting: https://www.dejavu.moe/posts/git-npm-yarn-proxy/
INFO  Bing Submitting: https://www.dejavu.moe/posts/hexo-next-beautify/
INFO  Bing Submitting: https://www.dejavu.moe/posts/hello-world/
INFO  Submitting google urls

INFO  Google Submitting: https://www.dejavu.moe/posts/hexo-permalinks/
INFO  Google Submitting: https://www.dejavu.moe/posts/hexo-seo/
INFO  Google Submitting: https://www.dejavu.moe/posts/c-note-3/
INFO  Google Submitting: https://www.dejavu.moe/posts/c-note-2/
INFO  Google Submitting: https://www.dejavu.moe/posts/c-note-1/
INFO  Google Submitting: https://www.dejavu.moe/posts/git-npm-yarn-proxy/
INFO  Google Submitting: https://www.dejavu.moe/posts/hexo-next-beautify/
INFO  Google Submitting: https://www.dejavu.moe/posts/hello-world/
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/hexo-seo/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/hexo-seo/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.204661533Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/c-note-2/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/c-note-2/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.205195666Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/hexo-permalinks/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/hexo-permalinks/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.291980560Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/git-npm-yarn-proxy/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/git-npm-yarn-proxy/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.268035510Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/hello-world/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/hello-world/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.285026675Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/c-note-3/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/c-note-3/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.383086191Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/hexo-next-beautify/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/hexo-next-beautify/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.357022535Z'
    }
  }
}
Google response:  {
  urlNotificationMetadata: {
    url: 'https://www.dejavu.moe/posts/c-note-1/',
    latestUpdate: {
      url: 'https://www.dejavu.moe/posts/c-note-1/',
      type: 'URL_UPDATED',
      notifyTime: '2021-06-16T18:59:29.469752812Z'
    }
  }
}
Bing response:  { d: null }
Bing response:  { d: null }
Bing response:  { d: null }
Bing response:  { d: null }
Bing response:  { d: null }
Bing response:  { d: null }
Bing response:  { d: null }
Bing response:  { d: null }

到此为止,关于 Hexo 的 SEO 优化套路就到此为止啦,以后就安心写作,等待被收录吧!收录速度个人感觉:必应 > 谷歌 > 百度

不管哪种方式,好好写作、优质内容、原创内容才是 SEO 最好的利器 😀

Hexo SEO 优化的基本套路

https://www.dejavu.moe/posts/hexo-seo/

作者

Dejavu

发布于

2021-06-16

更新于

2021-06-19

许可协议

评论