基於 hapi 的博客系統 api

📕 hapiblog 博客 api

基於 hapi 框架的博客系統,使用 jwt 鑑權,支持用戶註冊和登陸,獲取文章列表和文章詳情。以 redis 做爲緩存解決方案,使用 mysql 數據庫和 sequelize 處理數據持久化。mysql

👕 DEMO

點擊這裏查看DEMOgit

🌈 支持的功能

  • 分頁獲取博客文章列表
  • 增查改刪博客文章
  • 根據標籤、標題和做者 ID 篩選文章
  • 獲取文章排行列表支持 30 天之內的文章閱讀量排行
  • 使用 redis 緩存請求的數據
  • 用戶的註冊和登陸以及 JSON WebToken 的鑑權
  • 經過 swagger 建立 API 文檔
  • 使用 hapi-good 日誌工具
  • 使用 sequelize 建立數據遷移

screencapture-127-0-0-1-8000-documentation-2018-10-07-21_48_37.png

🎉 使用方法

🍎 clone

git clone https://github.com/oliyg/hapiblog.git

🚨 配置環境變量

根目錄新增 .env 文件,仿照 .env.example 配置環境變量:github

# server
HOST = HOST
PORT = PORT
 
# mysql
MYSQL_USERNAME = MYSQL_USERNAME
MYSQL_PASSWORD = MYSQL_PASSWORD
MYSQL_DB_NAME = MYSQL_DB_NAME
MYSQL_HOST = MYSQL_HOST
MYSQL_PORT = MYSQL_PORT
 
# redis
REDIS_HOST = REDIS_HOST
REDIS_PORT = REDIS_PORT
 
# jwt
JWT_SECRET = JWT_SECRET
 
# passwd encrypt secret
PASSWD_SECRET = PASSWD_SECRET

📖 數據遷移

開啓 mysql 服務,並執行命令:redis

  • npm run createdb:dev 建立數據庫
  • npm run createtable 建立數據庫表
  • npm run initdata 建立示例數據
  • npm run start 開啓服務

✈️ 啓動服務

訪問 http://127.0.0.1:8000/documentation#/ 查看 API 文檔sql

相關文章
相關標籤/搜索