zoukankan      html  css  js  c++  java
  • 基于 Hexo + GitHub Pages 搭建个人博客(三)

    这个系列我们前面已经更新了两篇,点击下列链接可直接访问:

    基于 Hexo + GitHub Pages 搭建个人博客(一)

    基于 Hexo + GitHub Pages 搭建个人博客(二)

    一、添加扫描二维码关注功能

    打开 themes 目录下的 next 主题配置文件,找到 Wechat Subscriber 标签,将该标签下的配置改成如下形式:

    # Wechat Subscriber
    wechat_subscriber:
      enabled: true			# 打开图片显示功能
      qcode: /images/wechat-qcode.jpg	# 需要显示的二维码图片
      description: 扫描二维码关注微信公众号,了解更多	# 在图片的底部添加描述
    

    配置完成后,切记将所需要扫描的二维码图片放置在 images 文件夹下面,否则系统找不到图片。

    结果如下图所示:

    二、添加文章赞赏功能

    打开 themes 目录下的 next 主题配置文件,找到 Reward 标签,将该标签下的配置改成如下形式:

    # Reward
    reward_comment: 赞赏是最好的支持与鼓励!	# 添加打赏描述
    wechatpay: /images/wechatpay.jpg	# 微信收款码图片
    alipay: /images/alipay.jpg		# 支付宝收款码图片
    #bitcoin: /images/bitcoin.png
    

    配置完成后,切记将所需要收款码图片放置在 images 文件夹下面,否则系统找不到图片。

    结果如下图所示:

    三、添加文章版权声明功能

    打开 themes 目录下的 next 主题配置文件,找到 Declare license on posts 标签,将该标签下的配置改成如下形式:

    # Declare license on posts
    post_copyright:
      enable: true		# 激活版权声明模块
      license: CC BY-NC-SA 3.0	# 版权许可协议
      license_url: https://compassblog.github.io/	# 声明的文章的可点击链接(域名)
    

    配置完成后,执行如下 主目录下打开 Git Bash 命令窗口,执行如下命令开启 hexo 服务器:

    hexo s
    

    浏览器访问,显示结果如下图所示:

    四、添加 Gitalk 评论系统

    1、什么是 Gitalk

    Gitalk 是一个基于 Github Issue 和 Preact 开发的评论插件,这款评论插件使用 Github 登录,也可以快速提交评论,其实有一款与 Gitalk 类似的评论插件叫 Gitment,然而这款有国内大神编写的评论插件已经不再维护,因此就只能选择国外的 Gitalk 了,并且 Gitalk 支持移动端。

    2、为什么要用 Gitalk

    我们知道 hexo 博客 的 Next 主题支持多种评论系统的继承,例如 Disqus,畅言,网易云跟帖,多说,来比力,友说,红杏等评论系统,但是这些评论系统要么不再提供服务,要么需要「科学上网」才能够加载,要么就是龟速加载,好吧,我想说的就是 Gitalk ,现在你明白为啥要用 Gitalk 了?

    3、Gitalk 评论系统集成

    (1)新建一个 GitHub 仓库,用于存放评论的记录,如下图所示:

    (2)在 GitHub 上新建一个 OAuth application : 点击这里可以直接新建

    新建 OAuth application 详细说明:

    Application name //第(1)点建立的仓库名称
    Homepage URL //博客地址
    Application description //可不填
    Authorization callback URL //博客地址
    

    如下图所示:

    完成后,我们回获得如下图中的相关信息,后面可能会用到:

    (3)创建 Gitalk 的 swig 文件,在博客的主目录中打开 themes/next/layout/_third-party/comments 文件夹,新建 gitalk.swig 文件,在文件中配置如下代码:

    {% if not (theme.duoshuo and theme.duoshuo.shortname) and not theme.duoshuo_shortname %}
      
      {% if theme.gitalk.enable %}  //_config.yml文件若没有添加enable: true可删除该判断
    
        {% if theme.gitalk.distractionFreeMode  %}      
    	  <link rel='stylesheet' href="https://yiyeti.cc/usr/themes/veryse/css/gitalk.css">
          <script src="https://yiyeti.cc/usr/themes/veryse/css/gitalk.min.js"></script>
          <script type="text/javascript">
              var gitalk = new Gitalk({
                clientID:  '{{theme.gitalk.clientID}}', 
                clientSecret: '{{theme.gitalk.clientSecret}}',
                id: window.location.pathname,
                repo: '{{theme.gitalk.repo}}', 
                owner: '{{theme.gitalk.owner}}', 
                admin: '{{theme.gitalk.admin}}', 
                distractionFreeMode: '{{theme.gitalk.distractionFreeMode}}',
              })
              gitalk.render('gitalk-container')
          </script>
        {% endif %}
    
      {% endif %}
    {% endif %}
    

    (4)在同样的目录下找到并打开 index.swig 文件,在文件中配置如下代码引入 gitalk.swig 文件:

    {% include 'gitalk.swig' %}
    

    (5)在博客的主目录中打开 themes/next/layout/_partials/ 文件夹,找到并打开 comments.swig 文件,找到最后一个if分支,即下面这个分支代码:

    {% elseif theme.valine.appid and theme.valine.appkey %}
          <div id="vcomments"></div>
    

    在这个 if 分支后加一个 Gitalk 的分支,代码如下:

    {% elseif theme.gitalk.enable %}
     <div id="gitalk-container"></div>
    

    (6)在 themes/next/_config.xml 主题配置文件中加入如下配置:

    gitalk:
      enable: true	# 是否开启 Gitalk 评论
      owner:  	# GitHub 用户名	 
      repo: 		#仓库名称
      ClientID: ******
      ClientSecret: ******
      admin: 	# GitHub 用户名
      distractionFreeMode: true
    

    到这里,Gitalk 评论系统基本就已经集成了。

    后记: 最近 GitHub 限制了访问 label 的长度,即当我们博客文章的标题标签转换成 Issue超过 50 个字符时,Gitalk 评论系统便无法进行初始化,即对我们博客题目有了限制。而对于这个问题的解决,目前的想法是可以通过 md5 转换的方式封装 id,后续如果有好的解决办法,再更新吧。

    扫描二维码关注微信公众号,了解更多

    ---------------------------------------------

  • 相关阅读:
    bzoj2301: [HAOI2011]Problem b懵逼乌斯反演
    bzoj3504: [Cqoi2014]危桥 网络流
    bzoj1588: [HNOI2002]营业额统计 splay瞎写
    bzoj1008快速面
    洛谷1212手动枚举各种情况(缩代码成瘾)
    bzoj1968真·想sha法bi题
    bzoj3674同上(好短)
    bzoj3673可持久化线段树实现可持久化数组实现可持久化并查集(好长)
    uoj98未来程序改 纯暴力不要想了
    bzoj3680模拟退火
  • 原文地址:https://www.cnblogs.com/compassblog/p/8911112.html
Copyright © 2011-2022 走看看