白嫖Github仓库和Cloudflare Workers简单快捷实现可分类的随机图片抽取
(写着玩,屎山,别喷我,叠甲,叠甲,叠甲,叠甲,叠甲)
希望类似YieldRay/Random-Picture食用方法的直接看方案3,4,5
https://demo2.randomimg.sfacg.ltd主页
https://demo2.randomimg.sfacg.ltd/api
https://demo2.randomimg.sfacg.ltd/api?cat=demoimg1
https://demo2.randomimg.sfacg.ltd/api?cat=demoimg&id=8没有对应资源返回状态码404和404.html
https://demo2.randomimg.sfacg.ltd/api?cat=demoimg&cat=demoimg1多分类抽取
https://demo2.randomimg.sfacg.ltd/api?cat=demoimg&id=4查看demoimg下的4.jpg
https://demo2.randomimg.sfacg.ltd/api?type=json默认分类抽取并返回json
https://demo2.randomimg.sfacg.ltd/api?cat=demoimg&id=2&type=json指定demoimg下的2.jpg返回json
https://demo2.randomimg.sfacg.ltd/api?cat=demoimg&type=302以302返回跳转到随机一张图的准确地址,供网页使用
PS:cloudflare提供的workers.dev域名在大陆无法正常解析,所以演示站是添加的自定义域名
Github随便新建个公开仓库,图片按1.jpg,2.jpg,3.jpg这样重命名后分类存到文件夹里,不分文件夹就只能设置默认文件夹抽取
Cloudflare Worker首页:https://workers.cloudflare.com
注册,登陆,start building,取一个worker子域名,创建服务,保持默认的即可。
进入编辑后复制 worker.js  到左侧代码框,按照代码中的注释和自己的需求修改代码,保存并部署。
- 
urlIndex:主页模板的地址
- 
url404:404页模板的地址
- 
imgHost:图片仓库的地址,通常为此格式https://raw.githubusercontent.com/<github用户名>/<仓库名>/<分支名>
- 
defaultPath:当访问的url为https://example.com/api时抽取图片的文件夹,你可以当成默认分类
- 
maxValues:用来抽图的文件夹名称和对应的图片数,以键值对形式存储,格式为'<名称>': <数量>,defaultPath以及对应数量应写为/<名称>: <数量>
- 
redirectProxy:返回类型为302时图片使用的代理,默认为2。0不使用代理(返回github原地址)1(不推荐)使用worker本身代理(返回https://example.com/api?id=1这样的链接)2(推荐)使用ghproxy代理(返回ghproxy.com代理的链接)PS:如果302返回使用的是worker代理,那么请求一次就是请求了worker两次。那我问你🤓👆 
- 
ghproxyUrl:github加速站的链接,ghproxy.com能正常使用就不需要改,更换地址通常按照此格式填写"https://example.com/"(不能漏掉结尾的/)
| 可用参数 | 值 | 说明 | 
|---|---|---|
| cat | 图片分类 (文件夹名) | 在该分类中抽取图片(没有该参数时从默认文件夹抽取) | 
| type | 302 | 通过302返回直接跳转到图片对应的准确地址,可用作随机网页背景等 | 
| json | 以json格式返回 | |
| id | <数值> | 返回名称为<数值>的指定图片(存在id时不允许type=302) | 
| 不使用参数 | 空 | 简简单单抽张图 | 
- 
从多个分类中抽取应按此格式 https://example.com/api?cat=value1&cat=value2
- 
json返回包含:分类 cat,图片idid,图片github原链接githubUrl,worker代理链接workerUrl,ghproxy代理链接proxyUrl
{
  "category": "demoimg1",
  "id": 2,
  "githubUrl": "https://raw.githubusercontent.com/Cheshire-Nya/easy-random-image-api/main/demoimg1/2.jpg",
  "workerUrl": "https://demo2.randomimg.sfacg.ltd/api?id=2&cat=demoimg1",
  "proxyUrl": "https://ghproxy.com/https://raw.githubusercontent.com/Cheshire-Nya/easy-random-image-api/main/demoimg1/2.jpg"
}
- 不知道还有啥问题,如果遇到了可以提issue
- 
cloudflare workers每个账户的免费额度是每天十万次请求,并且有每分钟1000次请求的限制,超出后请求会返回错误。如果不够用,可升级到 $5 的高级版本,每月可用 1000 万次请求(超出部分 $0.5/百万次请求) 
- 
cloudflare注册没有花里胡哨的各种认证,超低门槛,有邮箱就能注册。 
- 
理论上可以无限白嫖,多注册几个账号,其他服务调用随机图时多写个逻辑返回错误请求另外的接口即可。唯一的成本是大陆访问需要绑自定义域名,但是域名可以白嫖免费域名或者一年十几二十块的便宜域名,四舍五入就是妹花钱。添加自定义域在Cloudflare控制台中 网站里按指引操作,选择free计划即可。
- 
错误返回偷懒没完善 
- 
主页和404页没啥卵用,建议用的时候删了 
- 
1.可以查看指定图片辣 
- 
2.支持返回json力 
- 
3.添加主页模板和404模板 
- 
4. /api?,/api/?,/api/1.jpg,/api/demoimg?防呆处理
- 
5.可以返回302到通过ghproxy或worker代理的图片地址,方便web使用不受浏览器缓存影响