注意:本仓库为Telegraph-Image项目的重制版,如果你觉得本项目不错,在支持本项目的同时,也请支持原项目。
体验视频:CloudFlare免费图床,轻松守护你的每一份精彩!_哔哩哔哩_bilibili
cf-pages/Telegraph-Image项目的重制版,实现了登录鉴权、页面自定义、上传图片预览、一键切换上传方式(拖拽上传、粘贴上传)、多文件上传、整体复制、多格式复制等功能。
-
开源
- 前端开源(可自行修改、打包使用)
-
炫酷的动效(
- 流畅丝滑的过渡动画~
- 上传文件实现呼吸灯效果
-
人性化上传
- 支持一键切换上传方式(拖拽点击、粘贴)
- 粘贴上传支持文件和URL
- 支持批量上传(不限同时选择文件数量,但为了保证稳定性,同时处于上传状态的文件最多为10个)
- 上传显示实时上传进度
- 上传后图片无需手动点击,可直接展示在管理页面中
-
多样化复制
- 支持整体复制和单独复制(整体复制即将所有链接通过换行串联起来后复制)
- 支持MarkDown、HTML、BBCode和原始链接四种格式复制
- 上传完成后直观展示四种格式链接
-
支持身份认证、防滥用
-
支持页面自定义
- 页面背景支持单图、自定义多图轮播、bing随机图轮播等多种模式
-
一些小功能
- 支持随机图API,从图床中随机返回一张图片
部署方式与环境变量和原仓库保持一致。
-
部署于Cloudflare
只需准备一个Cloudflare账户,然后按照3.1.2.1节的步骤即可完成部署。
-
部署于服务器
如果Cloudflare的有限访问次数不能满足你的需求,并且你拥有自己的服务器,可以参照3.1.2.2节的教程在服务器上模拟Cloudflare的环境,并开放对应的端口访问服务。
注意由于服务器操作系统、硬件版本复杂多样,相关教程无法确保适合每一位用户,遇到报错请尽量利用搜索引擎解决,无法解决也可以提issue寻求帮助。
依托于CF的强大能力,只需简单 3 步,即可部署本项目,拥有自己的图床。
-
Fork 本仓库 (注意:必须使用 Git 或者 Wrangler 命令行工具部署后才能正常使用,文档)
-
打开 Cloudflare Dashboard,进入 Pages 管理页面,选择创建项目,选择
连接到 Git 提供程序
- 按照页面提示输入项目名称,选择需要连接的 git 仓库,点击
部署站点
即可完成部署
-
安装服务器操作系统对应的
node.js
,经测试v22.5.1
版本可以正常使用。(安装教程自行search) -
切换到项目根目录,运行
npm install
,安装所需依赖。 -
在项目根目录下新建
wrangler.toml
配置文件,其内容为项目名称,环境变量等,可根据后文环境变量配置进行个性化修改。(详情参见官方文档Configuration - Wrangler (cloudflare.com))配置文件样例:
name = "cloudflare-imgbed" compatibility_date = "2024-07-24" [vars] ModerateContentApiKey = "your_key" AllowRandom = "true" BASIC_USER = "user" BASIC_PASS = "pass"
-
在项目根目录下运行
npm run start
,至此,正常情况下项目已经成功部署。程序默认运行在
8080
端口上,使用nginx
等服务器反代127.0.0.1:8080
即可外网访问服务。如需修改端口,可在package.json
中修改start
脚本的port
参数(如下图)。正常启动,控制台输出如下:
- 默认关闭,开启方式如下:
- 创建一个新的KV数据库
- 进入项目对应
设置
->函数
->KV 命名空间绑定
->编辑绑定
->变量名称
,填写img_url
,KV命名空间选择刚才创建好的KV数据库 - 设置好后,访问
http(s)://你的域名/admin
即可进入后台管理页面
- 管理员认证,默认关闭,开启方式如下:
- 项目对应
设置
->环境变量
->为生产环境定义变量
->编辑变量
,添加BASIC_USER
作为管理员用户名,BASIC_PASS
作为管理员登录密码
- 项目对应
支持成人内容审查和自动屏蔽,开启步骤如下:
- 前往https://moderatecontent.com/ 注册并获得一个免费的用于审查图像内容的 API key
- 打开 Cloudflare Pages 项目的管理页面,依次点击
设置
,环境变量
,添加环境变量
- 添加一个
变量名称
为ModerateContentApiKey
,值
为第一步获得的API key
,点击保存
即可
环境变量增加认证码AUTH_CODE
,值为你想要设置的认证码。
Web端在登录页面输入你的认证码即可登录使用。
API格式:
接口名称 | /upload |
---|---|
接口功能 | 上传图片或视频 |
请求方法 | POST |
请求参数 | Query参数:authCode ,string类型,即为你设置的认证码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
环境变量增加USER_CONFIG
,JSON格式,具体字段用途及内容规范见下表。
字段名 | 用途 | 类型 | 内容规范 |
---|---|---|---|
loginBkImg | 自定义登录页面背景 | 列表/字符串 | 1、当字段类型为列表 时,列表中元素为需要添加到轮播列表中的图片链接(列表中只有一张图时即为固定背景),形如["1.jpg","2.jpg"] 2、当字段类型为 字符串 时,目前仅支持字符串值为bing ,设置为该值时启用bing随机图片轮播模式。 |
uploadBkImg | 自定义上传页面背景 | 列表/字符串 | 同上 |
整体示例:
轮播模式: { "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"] } 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" }
修改环境变量后需要重新部署才能生效!
按照3.1
步骤部署完成后,前往仓库MarSeventh/Sanyue-ImgHub,按照操作说明进行DIY和打包操作,最后将打包好的/dist
目录中的内容替换到该仓库的根目录下即可(复制+替换)。
增加粘贴图片上传功能(2024.7.22已完成)增加markdown、html等格式链接复制功能(2024.7.21已完成)上传页面增加管理端入口(2024.7.21已完成)- 增加用户个性化配置接口
登录页面和上传页面背景图自定义(2024.8.25已完成)
增加随机图API(2024.7.25已完成)完善多格式链接展示形式,增加ubb格式链接支持(2024.8.21已完成)完善登录逻辑,后端增加认证码校验接口(2024.8.21已完成)支持URL粘贴上传(2024.8.23已完成)
修复API上传无法直接展示在后台的问题(2024.7.25已修复)
- 请检查你的cloudflare防火墙设置(例如hotlink保护是否开启)
- 参见Issue #8
-
PicGo插件设置中搜索
web-uploader
,安装可自定义前缀的版本,如图: -
打开
图床设置
->自定义Web图床
->Default
,然后按照下图方式配置,注意API地址和自定义图片URL前缀按照自己的域名进行修改: -
设置完成,确定即可使用PicGo上传到自建的图床。
前端开源,参见MarSeventh/Sanyue-ImgHub项目。
如果觉得项目不错希望您能给个免费的star✨✨✨,非常感谢!