使用 Stikked 運行您自己的 Pastebin

如果您是任何類型的開發人員,您可能聽說過 Pastebin.com,這是使用最廣泛的用於粘貼和共享文本片段的 Web 應用程序。 Pastebin.com 很棒,但它並不是唯一的 Pastebin 工具。

事實上,網站託管自己的 Pastebin 已經變得越來越普遍。 它給你更多的自由。 有許多開源的 Pastebin 實現,Stikked 是其中最有用的實現之一,具有先進的功能和簡化的用戶界面。

內容

卡住 使用 PHP 和 jQuery 構建,並使用 CodeIgniter 框架。

安裝插頭

Stikked 要求您的服務器正在運行:

  • git
  • Nginx
  • Docker 和 Docker 組合
  1. 要下載最新版本的 Stikked,請訪問 Stikked GitHub 頁面或轉到命令行並運行:
git clone https://github.com/claudehohl/Stikked.git
  1. 轉到 Stikked 文件夾:
cd ./Stikked
  1. 使用您喜歡的文本編輯器打開其中的“docker-compose.yml”文件。
  2. 滾動到“services:”類別下的“ports:”變量,並將其值更改為以下內容:
ports:
    - 8080:80/tcp
  1. 滾動到“mysql:”類別並將“command:”子類別替換為以下代碼:
command: mysqld
  1. 打開 Stikked 主配置文件:
nano ~/Stikked/docker/stikked.php
  1. 轉到包含變量的行 $config['base_url'] 並將“localhost”替換為系統的完全限定域名。 保存並退出文件。
  1. 打開 Stikked 容器內的“nginx.conf”文件:
nano ~/Stikked/docker/nginx.conf
  1. 刪除“僅允許向我們的主機發出請求”下面的三行。
突出顯示 docker 一部分的終端 Nginx 要刪除的配置。
  1. 通過運行以下命令構建 Docker 容器:
docker compose up -d

供參考: 了解如何在以下位置託管您自己的看板 Linux 使用 Docker 和 Kanboard。

創建 SSL Nginx 反向代理

此時,您現在已經在端口 8080 上運行了 Stikked 安裝。雖然您可以按原樣使用它,但基本的 Stikked 容器可能不安全,因為它默認不加密其連接。 要解決此問題,您需要創建一個反向代理來偵聽傳入連接,然後通過 SSL 對其進行加密。

  1. 在“/etc/nginx/sites-available/”下創建一個新的站點配置文件
sudo nano /etc/nginx/sites-available/stikked
  1. 將以下代碼粘貼到新站點文件中。 這是一個簡單的反向代理,它偵聽端口 80 上傳入的未加密連接,並將所有查詢重定向到端口 8080。
server {
    listen 80;
    listen [::]:80;
 
    root                    /var/www/html;
    server_name             my-stikked-installation.com;
 
    location / {
        proxy_set_header    X-Forwarded-For $remote_addr;
        proxy_set_header    Host $http_host;
        proxy_pass          https://localhost:8080;
    }
}
終端顯示 example Nginx  反向代理配置。
  1. 在“/etc/nginx/sites-enabled”中為站點文件創建一個符號鏈接,並刪除其中的默認站點文件:
sudo ln -s /etc/nginx/sites-available/stikked /etc/nginx/sites-enabled/
  1. 測試你的 Nginx 配置是否有任何錯誤,然後啟用 Nginx 服務通過 systemctl:
sudo nginx -t
sudo systemctl reload nginx.service

安裝 SSL 證書

反向代理啟動並運行後,您現在可以為 Stikked 實例請求 SSL 證書。 最簡單的選擇是安裝來自 Electronic Frontier Foundation 的 certbot snap 包。

  1. 確保您的核心快照二進製文件是最新的並且正在運行:
sudo snap install core
sudo snap refresh core
  1. 使用 Stikked 機器的 snap 二進製文件安裝 certbot:
sudo snap install certbot --classic
顯示 certbot 安裝過程的終端。
  1. 通過將您的電子郵件地址鏈接到 certbot 來測試程序是否正常運行:
sudo certbot register --agree-tos -m ramces@email.invalid
  1. 再次運行 certbot 為您的 Stikked 實例創建 SSL 證書:
sudo certbot --nginx -d my-stikked-installation.com
  1. 打開 Web 瀏覽器並檢查您的 Stikked 實例是否在 SSL 下運行。
顯示正在運行的 Stikked 實例的屏幕截圖。

很高興知道: 通過 OpenSSL 頒發您自己的 SSL 證書,了解加密如何在 Internet 上工作。

設計您的固定安裝

所有樣式數據都存在於 Git 存儲庫的“htdocs”目錄下名為“themes”的目錄中。 如果想要刺激一下,請查看子目錄內部以查看一些有趣的選擇。

  1. 進入 Stikked Git 存儲庫並導航到“htdocs/themes”目錄。
cd ~/Stikked/htdocs/themes
  1. 大多數樣式選擇都是在每個主題文件夾內進行的。 為了 example,geocity 主題將您的 Stikked 變成了 20 世紀 90 年代的網站。
顯示 Stikked 復古主題的屏幕截圖。
  1. 為了修改實例的外觀,您需要首先關閉 Docker 容器:
docker compose down
  1. 使用您喜歡的文本編輯器打開實例的主配置文件:
nano ~/Stikked/docker/stikked.php
  1. 向下滾動到包含以下內容的行 $config['theme'] 變量並將其值更改為“cleanwhite”。
顯示當前實例的主題變量的終端。
  1. 保存主配置文件並重新加載 Docker 容器:
docker compose up -d
  1. 打開網絡瀏覽器並加載新網頁。 這是加載 cleanwhite 主題後的“創建”頁面。
顯示 Stikked 以 cleanwhite 主題運行的屏幕截圖。

特徵

Stikked 具有許多有趣的功能,使其從眾多其他 Pastebin 腳本中脫穎而出。

首先,它在語法突出顯示方面表現出色。 Stikked 支持大量編程和腳本語言,從 C 到 Bash。 無論您使用什麼編碼,Stikked 安裝都能滿足您的需求。

顯示 Stikked 語法突出顯示功能的屏幕截圖。

每個片段的語言顯示在“最近”頁面上的表格中; 如果發帖者沒有指定粘貼的語言,則它會被標記為“文本”。 該表還顯示標題、發帖人姓名、新近度以及 RSS 圖標。 RSS 提要位於 your-stikked-installation.com/lists/rss

顯示 Stikked 實例的裸 RSS 源的屏幕截圖。

“趨勢”頁面幾乎相同,但增加了“點擊”欄並且沒有 RSS 提要。 點擊數似乎是根據唯一 IP 地址的訪問來計算的。

顯示當前實例中趨勢粘貼列表的屏幕截圖。

創建粘貼時,您可以選擇設置到期日期、使用 bit.ly 的服務創建短 URL 和/或將帖子設置為私有。 請注意,“私人”粘貼並不是真正的私人; 任何擁有粘貼 URL 的用戶都可以看到它,除非您啟用了 LDAP 身份驗證 – 在這種情況下,每個擁有該 URL 的註冊用戶都可以看到它。 “私人”僅意味著該帖子不會顯示在“最近”或“趨勢”頁面上。

顯示私人粘貼的屏幕截圖。

除了安全性之外,Stikked 還提供了一些用於查看粘貼的簡潔實用程序。 我對嵌入代碼特別滿意。

屏幕截圖顯示 example 嵌入當前粘貼的片段。

您還可以回复粘貼並從原始粘貼下方的表單添加您自己的編輯。 唯一的缺點是回復不會鏈接回原始帖子; 如果您的 Pastebin 有許多不同的帖子和在不同時間做出的回复,則很容易忘記它們的結構。 我只能希望開發人員能夠在某個時候引入線程回复。

最後一項功能是垃圾郵件控制,Stikked 將其稱為“spamadmin”。 通過在第 79 行和第 80 行的“docker/stikked.php”中輸入憑據來進行設置:

$config['spamadmin_user'] = 'stikked';
$config['spamadmin_pass'] = 'stikked';

your-stikked-installation.com/spamadmin 登錄。您可以在其中查看哪些粘貼來自哪些 IP 地址、刪除粘貼以及阻止 IP 範圍。

顯示 Stikked 的 spamadmin 控制面板的屏幕截圖。

應用程序編程接口

Stikked 的 API 允許您從 Pastebin 客戶端粘貼到它。 在您的客戶端中使用的 API URL 是 your-stikked-installation.com/api/create

一個基本的 example 是使用 cURL 命令上傳一個名為“smalltalk.st”的文件,設置標題、名稱、隱私、語言和過期時間(以分鐘為單位):

curl -d title='cURL test' -d name='Ramces' -d private=1 -d lang=c -d expire=45 --data-urlencode text@count.c https://my-stikked-installation.com/api/create

這將返回粘貼的 URL。

屏幕截圖顯示 example 使用 Stikked API 製作的粘貼。

如果您想要一種簡單的方法來在自己的網站上收集和共享文本片段,我建議您嘗試一下 Stikked。

在這一點上,快速獲取一些文本片段進行分享的一種方法是學習一門新的編程語言。 通過閱讀我們的簡單初學者指南,了解如何編寫 Bash 腳本。 您還可以通過閱讀我們對 Bash 變量及其用途的深入研究來擴展這些知識。

圖片來源: 克里斯托弗·高爾(Christopher Gower)來自 Unsplash。 所有修改和屏幕截圖均由 Ramces Red 進行。

訂閱我們的新聞!

我們的最新教程直接發送到您的收件箱

訂閱所有時事通訊。

註冊即表示您同意我們的隱私政策,並且歐洲用戶同意數據傳輸政策。 我們不會分享您的數據,您可以隨時取消訂閱。

訂閱