免费图片托管解决方案,基于 Cloudflare Pages 和 Telegram,支持 Telegram Bot 存储渠道和 Cloudflare R2 存储渠道。
体验地址:Sanyue ImgHub (demo-cloudflare-imgbed.pages.dev)
访问码:cfbed
体验视频:CloudFlare免费图床,轻松守护你的每一份精彩!_哔哩哔哩_bilibili
相关优质博文(感谢每一位鼎力支持的热心大佬):
注意:本仓库为Telegraph-Image项目的重制版,如果你觉得本项目不错,在支持本项目的同时,也请支持原项目。
[!IMPORTANT]
由于telegraph图床被滥用,该项目上传渠道已切换至Telegram Channel,请更新至最新版(更新方式见第3.1章最后一节),按照文档中的部署要求设置
TG_BOT_TOKEN
和TG_CHAT_ID
,否则将无法正常使用上传功能。此外,目前KV数据库为必须配置,如果以前未配置请按照文档说明配置。
出现问题,请先查看第5节常见问题Q&A部分。
免费图片托管解决方案(支持存储绝大多数常见格式的图片、视频、动图等),具有后台管理、图片审查、登录鉴权、页面自定义、多种方式及多文件上传、多文件及多格式链接复制等功能(详见第2章)。
此外,拖拽上传的方式并没有严格限制文件类型,理论上你可以上传任何文件,但是暂时不会针对图片和视频外的文件进行特殊优化和适配。
开源
炫酷的动效(
人性化上传
支持绝大多数常见图片、视频、动图等
支持 Telegram Bot, Cloudflare R2 等多种存储渠道一键切换
Telegram Bot渠道:上传文件大小限制为20MB,提供客户端和服务端压缩功能
Cloudflare R2渠道:上传大小不限,但超过免费额度会扣费,详见Pricing | Cloudflare R2 docs
支持多种上传方式(拖拽点击、粘贴)
粘贴上传支持文件和URL
支持批量上传(不限同时选择文件数量,但为了保证稳定性,同时处于上传状态的文件最多为10个)
上传显示实时上传进度
上传后图片无需手动点击,可直接展示在管理页面中
过大图片在前端进行压缩,提升上传稳定性和加载性能
支持自定义压缩质量,自定义开启前后端压缩功能
多样化复制
支持身份认证、防滥用
支持页面自定义
一些小功能
以及原版所有特性
1.无限图片储存数量,你可以上传不限数量的图片
2.无需购买服务器,托管于 Cloudflare 的网络上,当使用量不超过 Cloudflare 的免费额度时,完全免费
3.无需购买域名,可以使用 Cloudflare Pages 提供的
*.pages.dev
的免费二级域名,同时也支持绑定自定义域名4.支持图片审查 API,可根据需要开启,开启后不良图片将自动屏蔽,不再加载
5.支持后台图片管理,可以对上传的图片进行在线预览,添加白名单,黑名单等操作
注意修改完环境变量,重新部署才能生效,见3.1章最后一节
版本更新方式,也请见3.1章最后一节
开通Telegram Bot渠道必须:Telegram的TG_BOT_TOKEN
和TG_CHAT_ID
首先需要拥有一个Telegram账户,然后按照以下步骤获取TG_BOT_TOKEN
和TG_CHAT_ID
。
向@BotFather发送/newbot
,按照提示输入bot的备注、用户名等信息。成功创建后获得TG_BOT_TOKEN
。
创建一个新的频道(Channel),进入新建的频道,选择频道管理,将刚才创建的机器人设为频道管理员。
向@VersaToolsBot转发一条第2步新建频道中的消息,获取TG_CHAT_ID
(频道ID)
开通Cloudflare R2渠道必须:新建一个Cloudflare R2存储桶,前提是需要绑定支付方式。
前往Cloudflare Dashboard,选择R2 存储对象
选择创建存储桶
,名称随意,填完后点击创建存储桶
即可完成创建
根据需求可选操作:如果需要启用图像审查,需要开启存储桶的公网访问权限,有两种开启方式,详见下图。无论你选择哪种方式,都需要记下完整的公网访问链接,格式为https://xxxx.xxx
部署于Cloudflare
需准备一个Cloudflare账户,然后按照3.1.2.1节的步骤即可完成部署。
部署于服务器
如果Cloudflare的有限访问次数不能满足你的需求,并且你拥有自己的服务器,可以参照3.1.2.2节的教程在服务器上模拟Cloudflare的环境,并开放对应的端口访问服务。
注意由于服务器操作系统、硬件版本复杂多样,相关教程无法确保适合每一位用户,遇到报错请尽量利用搜索引擎解决,无法解决也可以提issue寻求帮助。
依托于CF的强大能力,只需简单几步,即可部署本项目,拥有自己的图床。
Fork 本仓库
打开 Cloudflare Dashboard,进入 Pages 管理页面,选择创建项目,选择连接到 Git 提供程序
按照页面提示输入项目名称,选择需要连接的 git 仓库,点击部署站点
根据所需存储渠道进行相关设置:
Telegram 渠道
:将3.1.1中获取的TG_BOT_TOKEN
和TG_CHAT_ID
分别添加到环境变量中,对应环境变量名为TG_BOT_TOKEN
和TG_CHAT_ID
Cloudflare R2 渠道
:
将前面新建的存储桶绑定到项目,名称为img_r2
如果后续要开启公网访问,需要设置R2PublicUrl
环境变量,值为前面记下的R2存储桶公网访问链接:
绑定KV数据库:
创建一个新的KV数据库
进入项目对应设置
->函数
->KV 命名空间绑定
->编辑绑定
->变量名称
,填写img_url
,KV命名空间选择刚才创建好的KV数据库
重试部署
,此时项目即可正常使用
安装服务器操作系统对应的node.js
,经测试v22.5.1
版本可以正常使用。(安装教程自行search)
切换到项目根目录,运行npm install
,安装所需依赖。
在项目根目录下新建wrangler.toml
配置文件,其内容为项目名称,环境变量(包括TG_BOT_TOKEN
和TG_CHAT_ID
等参数)等,可根据后文环境变量配置进行个性化修改。(详情参见官方文档Configuration - Wrangler (cloudflare.com))
配置文件样例:
name = "cloudflare-imgbed" compatibility_date = "2024-07-24" [vars] ModerateContentApiKey = "your_key" AllowRandom = "true" BASIC_USER = "user" BASIC_PASS = "pass" TG_BOT_TOKEN = "your_bot_token" TG_CHAT_ID = "your_bot_id"
在项目根目录下运行npm run start
,至此,正常情况下项目已经成功部署。项目默认支持通过服务器本地模拟的R2存储上传。
程序默认运行在8080
端口上,使用nginx
等服务器反代127.0.0.1:8080
即可外网访问服务。如需修改端口,可在package.json
中修改start
脚本的port
参数(如下)。
"scripts": {
"ci-test": "concurrently --kill-others \"npm start\" \"wait-on http://localhost:8080 && mocha\"",
"test": "mocha",
"start": "npx wrangler pages dev ./ --kv \"img_url\" --r2 \"img_r2\" --port 8080 --persist-to ./data"
}
正常启动,控制台输出如下:
后台管理页面默认不设密码,需按照如下方式设置认证:
配置管理员认证:
设置
->环境变量
->为生产环境定义变量
->编辑变量
,添加BASIC_USER
作为管理员用户名,BASIC_PASS
作为管理员登录密码重新部署项目:
进入项目对应部署
->所有部署
,选择最新的一个,点击后面更多按钮(···
),选择重试部署
部署完成后,访问http(s)://你的域名/dashboard
即可进入后台管理页面
支持成人内容审查和自动屏蔽,开启步骤如下:
设置
,环境变量
,添加环境变量
变量名称
为ModerateContentApiKey
,值
为第一步获得的API key
,点击保存
即可环境变量增加认证码AUTH_CODE
,值为你想要设置的认证码。
Web端在登录页面输入你的认证码即可登录使用。
API格式:
接口名称 | /upload |
---|---|
接口功能 | 上传图片或视频 |
请求方法 | POST |
请求参数 | Query参数:authCode ,string类型,即为你设置的认证码serverCompress ,boolean类型,表示是否开启服务端压缩(仅针对图片文件、Telegram上传渠道生效)uploadChannel ,string类型,取值为telegram 和cfr2 ,分别代表telegram bot渠道和Cloudflare R2渠道,默认为telegram bot渠道Body参数(application/form-data): file ,file类型,你要上传的文件 |
返回响应 | data[0].src 为获得的图片链接(注意不包含域名,需要自己添加) |
请求示例:
curl --location --request POST 'https://your.domain/upload?authCode=your_authCode' \ --header 'User-Agent: Apifox/1.0.0 (https://apifox.com)' \ --form 'file=@"D:\\杂文件\\壁纸\\genshin109.jpg"'
响应示例:
[ { "src": "/file/738a8aaacf4d88d1590f9.jpg" } ]
环境变量增加ALLOWED_DOMAINS
,多个允许的域名用英文,
分割,如:域名.xyz,域名.cloudns.be,域名.pp.ua
环境变量增加WhiteList_Mode
,设置为true
即可开启白名单模式,仅设置为白名单的图片可被访问。
环境变量增加USER_CONFIG
,JSON格式,具体字段用途及内容规范见下表。
字段名 | 用途 | 类型 | 内容规范 |
---|---|---|---|
loginBkImg | 自定义登录页面背景 | 列表/字符串 | 1、当字段类型为列表 时,列表中元素为需要添加到轮播列表中的图片链接(列表中只有一张图时即为固定背景),形如["1.jpg","2.jpg"] 2、当字段类型为 字符串 时,目前仅支持字符串值为bing ,设置为该值时启用bing随机图片轮播模式。 |
uploadBkImg | 自定义上传页面背景 | 列表/字符串 | 同上 |
bkInterval | 轮播背景切换时间间隔 | 正整数 | 设置为背景图的轮播时间,默认3000 ,单位ms 。例如你希望10s切换一次,设置为 10000 即可。 |
bkOpacity | 背景图透明度 | (0,1]的浮点数 | 展示的背景图透明度,默认为1 。如果你觉得显示效果不佳,可以自定义,如 0.8 |
ownerName | 页内图床名称 | 字符串 | 只支持字符串 类型,设置为你自定义的图床名称(默认为Sanyue ) |
logoUrl | 页内图床Logo | 字符串 | 只支持字符串 类型,设置为你自定义的图床Logo链接 |
siteTitle | 网站标题 | 字符串 | 只支持字符串 类型,设置为你自定义的网站标题 |
siteIcon | 网站图标 | 字符串 | 只支持字符串 类型,设置为你自定义的网站图标链接 |
footerLink | 页脚传送门链接 | 字符串 | 只支持字符串 类型,设置为你自定义的传送地址(如个人博客链接) |
整体示例:
轮播模式: { "uploadBkImg": ["https://imgbed.sanyue.site/file/6910f0b5e65ed462c1362.jpg","https://imgbed.sanyue.site/file/a73c97a1e8149114dc750.jpg"], "loginBkImg":["https://imgbed.sanyue.site/file/ef803977f35a4ef4c03c2.jpg","https://imgbed.sanyue.site/file/0dbd5add3605a0b2e8994.jpg"], "ownerName": "Sanyue", "logoUrl": "https://demo-cloudflare-imgbed.pages.dev/random?type=img" } bing随机图模式: { "uploadBkImg": "bing", "loginBkImg": "bing" }
便于开发者进行bug的捕捉和定位,但是过程中可能收集到访问链接、域名等信息,如您不愿意泄露类似信息给项目开发者,可在环境变量中添加disable_telemetry
为true
来退出遥测。
接口名称 | /random |
---|---|
接口功能 | 从图床中随机返回一张图片的链接(注意会消耗列出次数) |
前置条件 | 设置AllowRandom 环境变量,值为true |
请求方法 | GET |
请求参数 | Query参数:type :设为img 时直接返回图片(此时form不生效);设为url 时返回完整url链接;否则返回随机图的文件路径。form :设为text 时直接返回文本,否则返回json格式内容。 |
响应格式 | 1、当type 为img 时:返回格式为 image/jpeg 2、当 type 为其他值时:当 form 不是text 时,返回JSON格式内容,data.url 为返回的链接/文件路径。否则,直接返回链接/文件路径。 |
请求示例:
curl --location --request GET 'https://your.domain/random' \ --header 'User-Agent: Apifox/1.0.0 (https://apifox.com)'
响应示例:
{ "url": "/file/4fab4d423d039b4665a27.jpg" }
修改环境变量方式:
修改环境变量后需要重新部署才能生效!
更新方式:
去到 Github 你之前 fork 过的仓库依次选择Sync fork
->Update branch
即可,稍等一会,Cloudflare Pages 检测到仓库更新之后便会自动部署最新代码。
如果有新的环境变量需要添加,请根据文档要求进行添加,然后重试部署。
按照3.1
步骤部署完成后,前往仓库MarSeventh/Sanyue-ImgHub,按照操作说明进行DIY和打包操作,最后将打包好的/dist
目录中的内容替换到该仓库的根目录下即可(复制+替换)。
ALLOWED_DOMAINS
,但无法跨域访问?PicGo插件设置中搜索web-uploader
,安装可自定义前缀的版本,如图:
打开图床设置
->自定义Web图床
->Default
,然后按照下图方式配置,注意API地址和自定义图片URL前缀按照自己的域名进行修改。(如果设置了AUTH_CODE
,一定以?authCode=your_authCode
的方式添加到API地址后面):
设置完成,确定即可使用PicGo上传到自建的图床。
TG_BOT_TOKEN
、TG_CHAT_ID
等环境变量TG_CHAT_ID
前面有没有-
-
前端开源,参见MarSeventh/Sanyue-ImgHub项目。
如果觉得项目不错希望您能给个免费的star✨✨✨,非常感谢!