如何将 Ghost 博客应用中的附件存储到腾讯云上COS
简介
Ghost 是一个基于 Node.js 快速搭建博客类网站的框架,开发者可通过 Ghost 官方 cli 工具一键生成自己的个人网站,并支持部署到云服务器和 Docker 上。
作为一个博客类网站,上传附件是必不可少的功能,Ghost 默认会将附件存储在本地,本文将介绍如何通过插件将附件保存在 腾讯云COS上,将附件保存在 COS 上有以下好处:
- 附件将拥有更高的可靠性。
- 您的云服务器无需为附件准备额外的存储空间。
- 用户查看图片附件时将直连 腾讯云COS 服务器,不占用您服务器的下行带宽/流量,用户访问速度更快。
- 可配合 腾讯云CDN 进一步提升用户查看图片附件的速度。
准备工作
搭建 Ghost 网站
- 安装 Node.js 环境。
- 安装 ghost-cli。
npm install ghost-cli@latest -g - 创建一个项目,在该项目的根目录下执行命令:
创建成功后的项目结构如下图所示:ghost install local![]()
- 打开浏览器,进入 localhost:2368,出现注册页面,注册后进入管理后台。
![]()
创建 腾讯云COS 存储桶
- 在 COS 控制台 创建一个访问权限为公有读私有写的存储桶,操作指引可参见 创建存储桶。
- 单击安全管理 > 跨域访问 CORS 设置,添加一行跨域设置,为方便调试可使用以下配置,操作指引可参见 设置跨域访问。
![]()
注意:
腾讯云COS特惠活动,新人1元起
将 Ghost 关联到 腾讯云COS存储桶
注意:
- 修改 Ghost 项目根目录下的 config.development.json 配置文件,添加如下配置:
参数说明如下:"storage": { "active": "ghost-cos-store", "ghost-cos-store": { "BasePath": "ghost/", // 可修改为自己的目录名,不填写则默认根目录 "SecretId": "AKID*************", "SecretKey": "***************", "Bucket": "xxx-125********", "Region": "**-*******" } }配置项 配置值 BasePath 文件所存储的 COS 路径,可自行修改,不填写则默认根目录 SecretId 访问密钥信息,可前往 云 API 密钥 中创建和获取 SecretKey 访问密钥信息,可前往 云 API 密钥 中创建和获取。 Bucket 创建存储桶时自定义的名称,例如 examplebucket-1250000000。 Region 创建存储桶时所选择的地域。 - 创建自定义存储目录,在项目根目录下执行:
mkdir -p content/adapters/storage - 安装腾讯云官方提供的 ghost-cos-store 插件。
- 通过 npm 安装。
npm install ghost-cos-store - 在 storage 目录下创建 ghost-cos-store.js 文件,内容如下:
// content/adapters/storage/ghost-cos-store.js module.exports = require('ghost-cos-store'); - 通过 git clone 安装。
cd content/adapters/storage git clone https://github.com/tencentyun/ghost-cos-store.git cd ghost-cos-store npm i - 安装完成后,需要重启 Ghost。
ghost restart
- 通过 npm 安装。
发文并进行上传测试
- 进入 Ghost 管理后台,单击发表一篇文章。
![]()
- 单击上传图片,在浏览器抓包可以看到 upload 请求成功,并返回了图片对应的 COS 链接。
![]()






浙公网安备 33010602011771号