PanSou 一款开源网盘搜索项目,集成前后端,一键部署,开箱即用_pansou github
PanSou 网盘搜索API
PanSou是一个高性能的网盘资源搜索API服务,支持TG搜索和自定义插件搜索。系统设计以性能和可扩展性为核心,支持并发搜索、结果智能排序和网盘类型分类。
项目地址:https://github.com/fish2018/pansou
特性(详见系统设计文档)
- 高性能搜索:并发执行多个TG频道及异步插件搜索,显著提升搜索速度;工作池设计,高效管理并发任务
- 网盘类型分类:自动识别多种网盘链接,按类型归类展示
- 智能排序:基于插件等级、时间新鲜度和优先关键词的多维度综合排序算法
- 异步插件系统:支持通过插件扩展搜索来源,支持\"尽快响应,持续处理\"的异步搜索模式,解决了某些搜索源响应时间长的问题。详情参考插件开发指南
- 二级缓存:分片内存+分片磁盘缓存机制,大幅提升重复查询速度和并发性能
支持的网盘类型
百度网盘 (baidu)、阿里云盘 (aliyun)、夸克网盘 (quark)、天翼云盘 (tianyi)、UC网盘 (uc)、移动云盘 (mobile)、115网盘 (115)、PikPak (pikpak)、迅雷网盘 (xunlei)、123网盘 (123)、磁力链接 (magnet)、电驴链接 (ed2k)、其他 (others)
预览



快速开始
在 Github 上先
本项目,并点上 Star !!!
使用Docker部署
前后端集成版
直接使用Docker命令
一键启动,开箱即用,无需任何配置
docker run -d --name pansou -p 80:80 ghcr.io/fish2018/pansou-web
使用Docker Compose(推荐)
# 下载配置文件curl -o docker-compose.yml https://raw.githubusercontent.com/fish2018/pansou-web/refs/heads/main/docker-compose.yml# 启动服务docker-compose up -d# 查看日志docker-compose logs -f
纯后端API
直接使用Docker命令
docker run -d --name pansou -p 8888:8888 -v pansou-cache:/app/cache -e CHANNELS=\"tgsearchers2,xxx\" ghcr.io/fish2018/pansou:latest
使用Docker Compose(推荐)
# 下载配置文件curl -o docker-compose.yml https://raw.githubusercontent.com/fish2018/pansou/refs/heads/main/docker-compose.yml# 启动服务docker-compose up -d# 访问服务http://localhost:8888
从源码安装
环境要求
- Go 1.18+
- 可选:SOCKS5代理(用于访问受限地区的Telegram站点)
- 克隆仓库
git clone https://github.com/fish2018/pansou.gitcd pansou
- 配置环境变量(可选)
🚀 基础配置
8888socks5://127.0.0.1:1080tgsearchers2🔧 高级配置(默认值即可)
点击展开高级配置选项(通常不需要修改)
60100304true./cache8hybridfalse10241001120- 构建
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags=\"-s -w -extldflags \'-static\'\" -o pansou .
- 运行
./pansou
其他配置参考
点击展开 supervisor 配置参考
[program:pansou]environment=PORT=8888,CHANNELS=\"tgsearchers2,yunpanxunlei,tianyifc,BaiduCloudDisk,txtyzy,peccxinpd,gotopan,xingqiump4,yunpanqk,PanjClub,kkxlzy,baicaoZY,MCPH01,share_aliyun,bdwpzhpd,ysxb48,jdjdn1111,yggpan,MCPH086,zaihuayun,Q66Share,NewAliPan,ypquark,Oscar_4Kmovies,ucwpzy,alyp_TV,alyp_4K_Movies,shareAliyun,alyp_1,dianyingshare,Quark_Movies,XiangxiuNBB,NewQuark,ydypzyfx,kuakeyun,ucquark,xx123pan,yingshifenxiang123,zyfb123,tyypzhpd,tianyirigeng,cloudtianyi,hdhhd21,Lsp115,oneonefivewpfx,Maidanglaocom,qixingzhenren,taoxgzy,tgsearchers115,Channel_Shares_115,tyysypzypd,vip115hot,wp123zy,yunpan139,yunpan189,yunpanuc,yydf_hzl,alyp_Animation,alyp_JLP,leoziyuan\"command=/home/work/pansou/pansoudirectory=/home/work/pansouautostart=trueautorestart=truestartsecs=5startretries=3exitcodes=0stopwaitsecs=10stopasgroup=truekillasgroup=true
点击展开 nginx 配置参考
server { listen 80; server_name pansou.252035.xyz; # 将 HTTP 重定向到 HTTPS return 301 https://$host$request_uri;}limit_req_zone $binary_remote_addr zone=api_limit:10m rate=60r/m;server { listen 443 ssl http2; server_name pansou.252035.xyz; access_log /home/work/logs/pansou.log; # 证书和密钥路径 ssl_certificate /etc/letsencrypt/live/252035.xyz/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/252035.xyz/privkey.pem; # 增强 SSL 安全性 ssl_protocols TLSv1.2 TLSv1.3; ssl_ciphers EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH; ssl_prefer_server_ciphers on; # 后端代理,应用限流 location / { # 应用限流规则 limit_req zone=api_limit burst=10 nodelay; # 当超过限制时返回 429 状态码 limit_req_status 429; proxy_pass http://127.0.0.1:8888; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; }}
API文档
搜索API
搜索网盘资源。
接口地址:/api/search
请求方法:POST 或 GET
Content-Type:application/json(POST方法)
POST请求参数:
GET请求参数:
POST请求示例:
{ \"kw\": \"速度与激情\", \"channels\": [\"tgsearchers2\", \"xxx\"], \"conc\": 2, \"refresh\": true, \"res\": \"merge\", \"src\": \"all\", \"plugins\": [\"jikepan\"], \"cloud_types\": [\"baidu\", \"quark\"], \"ext\": { \"title_en\": \"Fast and Furious\", \"is_all\": true }}
GET请求示例:
GET /api/search?kw=速度与激情&channels=tgsearchers2,xxx&conc=2&refresh=true&res=merge&src=tg&cloud_types=baidu,quark&ext={\"title_en\":\"Fast and Furious\",\"is_all\":true}
成功响应:
{ \"total\": 15, \"results\": [ { \"message_id\": \"12345\", \"unique_id\": \"channel-12345\", \"channel\": \"tgsearchers2\", \"datetime\": \"2023-06-10T14:23:45Z\", \"title\": \"速度与激情全集1-10\", \"content\": \"速度与激情系列全集,1080P高清...\", \"links\": [ { \"type\": \"baidu\", \"url\": \"https://pan.baidu.com/s/1abcdef\", \"password\": \"1234\" } ], \"tags\": [\"电影\", \"合集\"], \"images\": [ \"https://cdn1.cdn-telegram.org/file/xxx.jpg\" ] }, // 更多结果... ], \"merged_by_type\": { \"baidu\": [ { \"url\": \"https://pan.baidu.com/s/1abcdef\", \"password\": \"1234\", \"note\": \"速度与激情全集1-10\", \"datetime\": \"2023-06-10T14:23:45Z\", \"source\": \"tg:频道名称\", \"images\": [ \"https://cdn1.cdn-telegram.org/file/xxx.jpg\" ] }, // 更多百度网盘链接... ], \"quark\": [ { \"url\": \"https://pan.quark.cn/s/xxxx\", \"password\": \"\", \"note\": \"凡人修仙传\", \"datetime\": \"2023-06-10T15:30:22Z\", \"source\": \"plugin:插件名\", \"images\": [] } ], \"aliyun\": [ // 阿里云盘链接... ] // 更多网盘类型... }}
字段说明:
source: 数据来源标识tg:频道名称: 来自Telegram频道plugin:插件名: 来自指定插件unknown: 未知来源
images: TG消息中的图片链接数组(可选字段)- 仅在来源为Telegram频道且消息包含图片时出现
错误响应:
{ \"code\": 400, \"message\": \"关键词不能为空\"}
健康检查
检查API服务是否正常运行。
接口地址:/api/health
请求方法:GET
成功响应:
{ \"channels\": [ \"tgsearchers2\" ], \"plugin_count\": 16, \"plugins\": [ \"pansearch\", \"panta\", \"qupansou\", \"hunhepan\", \"jikepan\", \"pan666\", \"panyq\", \"susu\", \"xuexizhinan\", \"hdr4k\", \"labi\", \"shandian\", \"duoduo\", \"muou\", \"wanou\", \"ouge\", \"zhizhen\", \"huban\" ], \"plugins_enabled\": true, \"status\": \"ok\"}


