mirror of
https://github.com/qaiu/netdisk-fast-download.git
synced 2025-12-16 12:23:03 +00:00
107 lines
2.9 KiB
Markdown
107 lines
2.9 KiB
Markdown
# parser
|
||
|
||
NFD 解析器模块:聚合各类网盘/分享页解析,统一输出文件列表与下载信息,供上层下载器使用。
|
||
|
||
- 语言:Java 17
|
||
- 构建:Maven
|
||
- 模块版本:10.1.17
|
||
|
||
## 依赖(Maven Central)
|
||
```xml
|
||
<dependency>
|
||
<groupId>cn.qaiu</groupId>
|
||
<artifactId>parser</artifactId>
|
||
<version>10.1.17</version>
|
||
</dependency>
|
||
```
|
||
- Gradle Groovy DSL:
|
||
```groovy
|
||
dependencies {
|
||
implementation 'cn.qaiu:parser:10.1.17'
|
||
}
|
||
```
|
||
- Gradle Kotlin DSL:
|
||
```kotlin
|
||
dependencies {
|
||
implementation("cn.qaiu:parser:10.1.17")
|
||
}
|
||
```
|
||
|
||
## 核心 API 速览
|
||
- WebClientVertxInit:注入/获取 Vert.x 实例(内部 HTTP 客户端依赖)。
|
||
- ParserCreate:从分享链接或类型构建解析器;生成短链 path。
|
||
- IPanTool:统一解析接口(parse、parseFileList、parseById)。
|
||
- **CustomParserRegistry**:自定义解析器注册中心(支持扩展)。
|
||
- **CustomParserConfig**:自定义解析器配置类(支持扩展)。
|
||
|
||
## 使用示例(极简)
|
||
```java
|
||
List<FileInfo> list = ParserCreate
|
||
.fromShareUrl("https://share.feijipan.com/s/3pMsofZd")
|
||
.createTool()
|
||
.parseFileList()
|
||
.toCompletionStage().toCompletableFuture().join();
|
||
```
|
||
完整示例与调试脚本见 parser/doc/README.md。
|
||
|
||
## 快速开始
|
||
- 环境:JDK >= 17,Maven >= 3.9
|
||
- 构建/安装:
|
||
```
|
||
mvn -pl parser -am clean package
|
||
mvn -pl parser -am install
|
||
```
|
||
- 测试:
|
||
```
|
||
mvn -pl parser test
|
||
```
|
||
|
||
## 自定义解析器扩展
|
||
本模块支持用户自定义解析器扩展。通过简单的配置和注册,你可以添加自己的网盘解析实现:
|
||
|
||
```java
|
||
// 1. 继承 PanBase 抽象类(推荐)
|
||
public class MyPanTool extends PanBase {
|
||
public MyPanTool(ShareLinkInfo info) {
|
||
super(info);
|
||
}
|
||
@Override
|
||
public Future<String> parse() {
|
||
// 使用 PanBase 提供的 HTTP 客户端
|
||
client.getAbs("https://api.example.com")
|
||
.send()
|
||
.onSuccess(res -> complete(asJson(res).getString("url")))
|
||
.onFailure(handleFail("请求失败"));
|
||
return future();
|
||
}
|
||
}
|
||
|
||
// 2. 注册到系统
|
||
CustomParserConfig config = CustomParserConfig.builder()
|
||
.type("mypan")
|
||
.displayName("我的网盘")
|
||
.toolClass(MyPanTool.class)
|
||
.build();
|
||
CustomParserRegistry.register(config);
|
||
|
||
// 3. 使用自定义解析器(仅支持 fromType 方式)
|
||
IPanTool tool = ParserCreate.fromType("mypan")
|
||
.shareKey("abc123")
|
||
.createTool();
|
||
String url = tool.parseSync();
|
||
```
|
||
|
||
**详细文档:** [自定义解析器扩展指南](doc/CUSTOM_PARSER_GUIDE.md)
|
||
|
||
## 文档
|
||
- parser/doc/README.md:解析约定、示例、IDEA `.http` 调试
|
||
- **parser/doc/CUSTOM_PARSER_GUIDE.md:自定义解析器扩展完整指南**
|
||
|
||
## 目录
|
||
- src/main/java/cn/qaiu/entity:通用实体(如 FileInfo)
|
||
- src/main/java/cn/qaiu/parser:解析框架 & 各站点实现(impl)
|
||
- src/test/java:单测与示例
|
||
|
||
## 许可证
|
||
MIT License
|