Skip to content

zkitefly/optifine-downloadfile-302

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

optifine-downloadfile-302

一个小小的 API,根据请求的文件名自动抓取并返回 OptiFine 官网页面OptiKai 官方页面 的下载链接。

部署

本仓库提供两种版本:

  • 部署至 Vercel 的 Python 版本(main.py) # 推荐

  • 部署至 Cloudflare Workers 的 JavaScript 版本(main.js)

Vercel

点击 Deploy with Vercel 按钮跳转至 Vercel 进行部署操作。

Cloudflare Workers

拷贝 main.jsoptikai.js所有完整代码覆盖workers.cloudflare.com/playground,然后点击右上角的 Deploy 按钮跳转至配置页面,设置并部署即可。

使用

在成功配置并部署 API 后,只需按照如下格式请求即可:

GET {apiRoot}/file/{fileName}
GET {apiRoot}/kfile/{fileName}
  • {apiRoot} 为该 API 的域名,类似于:https://of-302v.zkitefly.eu.org

  • {fineName} 为需要下载的文件名,该文件名必须含有 OptiFine_.jar,否则将返回 404 Not Found 状态码。

抓取策略

以下为抓取下载链接的逻辑:

  • 获取 https://optifine.net/adloadx?f= + fileName 页面的下载链接,并检查该链接是否为 200 OK 状态码和 HTTP 标头是否含有 Content-Disposition 属性

    • 如果是
      • 302 Found 状态码返回 OptiFine 官网页面的下载链接
    • 如果不是
      • 尝试获取 BMCLAPIOptiFine 列表 并查找该 fileName 是否存在于该列表中
        • 如果该列表存在该 fileName
        • 如果该列表不存在该 fileName
          • 返回 404 Not Found 状态码
  • 获取 https://livzmc.net/optikai/downloadx?f= + fileName 页面的下载链接,并检查该链接是否为 200 OK 状态码和 HTTP 标头是否含有 Content-Disposition 属性

    • 如果是
      • 302 Found 状态码返回 OptiFine 官网页面的下载链接
    • 如果不是
      • 返回 404 Not Found 状态码

fileName 列表

可使用 BMCLAPI 的 OptiFine 列表 中的 filename 数据,或使用来自 zkitefly/optifine-download-list 的自动抓取列表中的 filename 数据。

演示站测试链接

Vercel:

https://of-302v.zkitefly.eu.org/file/OptiFine_1.20.1_HD_U_I6.jar
https://of-302v.zkitefly.eu.org/kfile/preview_OptiFine_1.21_HD_K_J3_pre11.jar

Cloudflare:

https://of-302.zkitefly.eu.org/file/OptiFine_1.20.1_HD_U_I6.jar

About

一个小小的 API,根据 fileName 自动抓取并返回 OptiFine 官网页面的下载链接。

Topics

Resources

Stars

Watchers

Forks