在Jekyll博客添加評(píng)論系統(tǒng):gitment篇

最近在Github Pages上使用Jekyll搭建了個(gè)人博客( jacobpan3g.github.io/cn ),當(dāng)需要添加評(píng)論系統(tǒng)時(shí),找了一下國(guó)內(nèi)的幾個(gè)第三方評(píng)論系統(tǒng),如“多說”,“暢言”,“友言”,“新浪云跟貼”:

  1. 多說,曾經(jīng)較火的評(píng)論系統(tǒng),網(wǎng)上介紹文章比較多,但已關(guān)閉,無法再用了
  2. 暢言,sohu旗下的,但是需要個(gè)人博客備案后才能使用,但github pages個(gè)人博客感覺備案比較難
  3. 友言,jiaThis旗下的,由于時(shí)http請(qǐng)求,github pages現(xiàn)在都是https了, 在https站點(diǎn)無法調(diào)用http請(qǐng)求,故也無法使用
  4. 網(wǎng)易云跟貼,曾被當(dāng)作“多說”的替代品,可惜官方通報(bào)說也將在2017.08.01關(guān)閉了

再看看disqus,國(guó)外比較火的評(píng)論系統(tǒng),但在國(guó)內(nèi)墻了,故也不考慮。

綜上,國(guó)內(nèi)幾個(gè)比較主流的評(píng)論系統(tǒng)目前都無法在Github Pages上的個(gè)人博客使用, 后面我發(fā)現(xiàn)了gitment,一款由國(guó)內(nèi)大神imsun開發(fā)的基于github issues的評(píng)論系統(tǒng), 具體介紹請(qǐng)看項(xiàng)目主頁( github.com/imsun/gitment )

目前我已經(jīng)成功把gitment應(yīng)用到了自己的Github pages個(gè)人博客里,過程中碰了一些壁, 同時(shí)發(fā)現(xiàn)網(wǎng)上關(guān)于gitment的介紹并不多,故寫一篇總結(jié),希望可以幫助到大家。

1. 申請(qǐng)一個(gè)Github OAuth Application

Github頭像下拉菜單 > Settings > 左邊Developer settings下的OAuth Application > Register a new application,填寫相關(guān)信息:

  1. Application name, Homepage URL, Application description 都可以隨意填寫
  2. Authorization callback URL 一定要寫自己Github Pages的URL
    (ps: 之前我自己就是在這里碰壁了,調(diào)試半天才發(fā)現(xiàn))
  3. 填寫完上述信息后按Register application按鈕,得到Client IDClient Secret

2. 在jekyll博客調(diào)用gitment

如gitment項(xiàng)目頁Readme所示,在你需要添加評(píng)論系統(tǒng)的地方,一般是_layout/目錄下的 post.html, 添加一下代碼

<div id="gitmentContainer"></div>
<link rel="stylesheet" >
<script src="https://imsun.github.io/gitment/dist/gitment.browser.js"></script>
<script>
var gitment = new Gitment({
    owner: 'Your GitHub username',
    repo: 'The repo to store comments',
    oauth: {
        client_id: 'Your client ID',
        client_secret: 'Your client secret',
    },
});
gitment.render('gitmentContainer');
</script>

需要修改的有4個(gè)地方

  1. Your GitHub username:填寫你的Github Pages博客所在的github賬戶名
  2. The repo to store comments:填寫用來存放評(píng)論的github倉庫,由于評(píng)論是 通過issues來存放的,個(gè)人建議這里可以直接填Github Pages個(gè)人博客所在的倉庫
  3. Your client ID:第1步所申請(qǐng)到的應(yīng)用的Client ID
  4. Your client secret:第1步所申請(qǐng)到的應(yīng)用的Client Secret

填寫完這4項(xiàng)把代碼保存上傳到github就可以了。

3. 為每篇博文初始化評(píng)論系統(tǒng)

由于gitment的原理是為每一遍博文以其URL作為標(biāo)識(shí)創(chuàng)建一個(gè)github issue, 對(duì)該篇博客的評(píng)論就是對(duì)這個(gè)issue的評(píng)論。因此,我們需要為每篇博文初始化一下評(píng)論系統(tǒng), 初始化后,你可以在你的github上會(huì)創(chuàng)建相對(duì)應(yīng)的issue。

接下來,介紹一下如何初始化評(píng)論系統(tǒng)

  1. 上面第2步代碼添加成功并上傳后,你就可以在你的博文頁下面看到一個(gè)評(píng)論框,還 有看到以下錯(cuò)誤Error: Comments Not Initialized,提示該篇博文的評(píng)論系統(tǒng)還沒初始化

  2. 點(diǎn)擊Login with GitHub后,使用自己的github賬號(hào)登錄后,就可以在上面錯(cuò)誤信息 處看到一個(gè)Initialize Comments的按鈕
    (ps: 由于要求回調(diào)URL和當(dāng)前地址一樣,故第2步不能在本地調(diào)試, 需把代碼先上傳再調(diào)試)

  3. 點(diǎn)擊Initialize Comments按鈕后,就可以開始對(duì)該篇博文開始評(píng)論了, 同時(shí)也可以在對(duì)應(yīng)的github倉庫看到相應(yīng)的issue

InitBtn

4. 一些問題

  • 安全問題

有些讀者擔(dān)心github oauth application的client secret這樣明文寫在頁面上會(huì)不會(huì)有安全 隱患,我也考慮到這個(gè)問題,目前我能想到比較好的解決方法是:注冊(cè)一個(gè)github小號(hào), 在小號(hào)里注冊(cè)oauth application,使用小號(hào)app的client secret

  • 回調(diào)URL

有些讀者反映登錄不成功,請(qǐng)大家一定要確認(rèn)github oauth application里的回調(diào)URL一定要 填寫要使用gitment的博客的URL,這一點(diǎn)十分重要


好了,gitment使用介紹到這里,大家若遇到什么問題盡管在下面留言,或者在我的個(gè)人博客 ( jacobpan3g.github.io/cn )留言,上面使用的評(píng)論系統(tǒng)就是gitment,我會(huì)抽空 一一作出回答。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,983評(píng)論 6 537
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,772評(píng)論 3 422
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,947評(píng)論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,201評(píng)論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,960評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,350評(píng)論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,406評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,549評(píng)論 0 289
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,104評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,914評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,089評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,647評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,340評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,753評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,007評(píng)論 1 289
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,834評(píng)論 3 395
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,106評(píng)論 2 375

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,799評(píng)論 18 139
  • Swift版本點(diǎn)擊這里歡迎加入QQ群交流: 594119878最新更新日期:18-09-17 About A cu...
    ylgwhyh閱讀 25,488評(píng)論 7 249
  • WebSocket-Swift Starscream的使用 WebSocket 是 HTML5 一種新的協(xié)議。它實(shí)...
    香橙柚子閱讀 24,003評(píng)論 8 183
  • 寫點(diǎn)什么呢?今天才是第三天。都已經(jīng)有了不知道該說什么的感覺了。寫自己身邊發(fā)生的事吧,又覺得身邊的事太小,不值...
    谷喵兒閱讀 269評(píng)論 0 0
  • 燈火通明下蚊蠅滋生 高樓大廈旁樓房坍圮 如今世界也萬不得已 她花容月貌下令人作嘔的面具 她窈窕身姿下惹人厭倦的塵埃...
    阿火moete閱讀 160評(píng)論 0 5