Web Analytics

asmr-downloader

⭐ 170 stars German by fireinrain

🌐 Sprache

📖 Projektübersicht

ASMRoner ist ein Kommandozeilen-Tool in Go, mit dem Sie asmr.one-Audios suchen, herunterladen, synchronisieren und eine einfache Web-Wiedergabeoberfläche bereitstellen können.

🌐 Abgeleitetes Projekt: asmr.furina.in — Eine schlichte und saubere Online-ASMR-Hörseite

🚀 Schnellstart

https://github.com/MIKANOoOo/asmr-downloader.git && cd asmroner
go build -o asmroner
./asmroner config   # 交互式初始化配置

📋 Häufig verwendete Befehle

# 搜索
./asmroner search "护士" -c 20
./asmroner search "护士,-中出@duration:1h" -c 50

下载

./asmroner download RJ01037721 -d ./downloads ./asmroner download RJ01037721,RJ02000001 -d ./downloads ./asmroner download hot100 -n 10 -d ./downloads

搜索 + 下载/导出

./asmroner search download "护士" -d ./downloads -s 20 ./asmroner search export "护士" -n 100 -f data.json

同步元数据 & 批量下载

./asmroner sync ./asmroner sync download -d ./downloads ./asmroner sync retry -d ./downloads ./asmroner sync report

# 导出单个作品或指定数量热门榜链接 & 导出到指定目录 ./asmroner export RJ01544940 -o ./downloads ./asmroner export hot100 -n 20 -o ./downloads ./asmroner export hot100 -n 10 -o ./downloads 更多内容参考常见问题中的guide

Web 播放界面

./asmroner listen -p 8080 ./syncdata

📸 Screenshots

| Konfiguration | Suche | |:---:|:---:| | Konfiguration | Suche | | Download | Synchronisieren | | Download | Synchronisieren | | Synchronisierter Download | Statistik | | Synchronisierter Download | Statistik | | Web-Oberfläche | Web-Oberfläche 2 | | Web-Oberfläche | Web-Oberfläche 2 | | Export-Oberfläche | Export-Oberfläche 2 | | Export-Oberfläche | Export-Oberfläche 2 |

✨ Funktionsmerkmale

  • Suche: Einzelne/mehrere RJIDs, erweiterte Suchsyntax, Export von Ergebnissen als CSV/JSON
  • Download: Einzel-/Massen-/Trend-Download, automatische Drosselung, Wiederholung, exponentielles Backoff
  • Synchronisation: Metadaten-Synchronisation, Steuerung des Massen-Downloads, Statusverfolgung, Wiederholung bei Fehlern
  • Web-Oberfläche: Visuelle Ansicht, Wiedergabe im Browser, responsives Design
  • Konfiguration: Interaktive Initialisierung, Unterstützung für Proxy, Drosselung, Jitter und weitere erweiterte Einstellungen

⚙️ Konfigurationsdatei-Erklärung

Pfad zur Konfigurationsdatei: ~/.asmroner/config.toml (TOML-Format)

[user]
account = "guest"
password = "guest"

[downloader] api_url = "" # 留空自动获取最快站点 proxy_url = "" # 支持 http / socks5 max_workers = 5 max_retries = 3 sync_data_folder = "./syncdata" sync_wanted_size = "200MB" # 同步容量限制 prefer_media = "all" # all | mp3>wav>flac

[limit] sync_qps = 2 sync_jitter_min = 100 # ms sync_jitter_max = 500 download_qps = 0.2 download_jitter_min = 2000 download_jitter_max = 5000

📋 Befehlsoptionen Schnellübersicht

| Befehl | Option | Beschreibung | |--------|--------|--------------| | search | -c | Anzahl der Suchergebnisse (Standard 10) | | search download | -d, -s | Download-Verzeichnis, Download-Anzahl | | search export | -f, -n | Exportdateiname (.csv/.json), Exportanzahl | | download | -d, -n | Download-Verzeichnis, hot100-Anzahl | | sync download | -d | Download-Verzeichnis | | sync retry | -d | Verzeichnis der fehlgeschlagenen Dateien | | sync export | -s, -f | Status (failed/success), Exportdatei | | listen | -p | Port (Standard 9999) | | export | -o, -n | Exportverzeichnis, hot100-Anzahl |

📁 Projektstruktur

asmroner/
├── cmd/                # 命令行接口(config/download/search/sync/listen)
├── internal/
│   ├── engine/        # 核心下载引擎(限流、重试、并发控制)
│   ├── logger/        # 结构化日志系统
│   ├── model/         # 数据模型与查询参数解析
│   ├── database/      # SQLite 数据库
│   ├── consts/        # 常量定义
│   └── utils/         # 工具函数
├── webui/             # 内嵌 Web 界面(Tailwind + Plyr)
├── main.go
└── go.mod

🛠 Technologiestack

| Komponente | Zweck | |------|------| | Cobra + Viper | CLI-Framework + Konfigurationsmanagement | | GORM + SQLite | Datenpersistenz | | Resty | HTTP-Client (unterstützt HTTP/SOCKS5-Proxy) | | Pond | Nebenläufiger Arbeits-Pool | | x/time/rate | Token-Bucket-Rate-Limiting | | Gin | Web-Service | | Tailwind + Plyr | Frontend-Oberfläche + Audiowiedergabe |

🔧 Häufige Fragen

Konfigurationsdatei nicht gefunden → Führe ./asmroner config zur Initialisierung aus

Download fehlgeschlagen (stream error) → Das Programm versucht es automatisch erneut; falls weiterhin fehlgeschlagen, verwende sync retry oder prüfe .asmroner-data/download_errors.log

Web-Oberfläche nicht erreichbar → Stelle sicher, dass der Port frei ist, versuche anderen Port mit -p anzugeben

Leere Suchergebnisse → Überprüfe die Suchsyntax, vereinfache ggf. die Bedingungen

Export-Befehl und zugehörige Downloadmethoden → Siehe guide

🤝 Beitrag

Pull Requests sind willkommen! Fork → neuen Branch erstellen → Änderungen commiten → PR eröffnen.

📄 Lizenz

Dieses Projekt steht unter der MIT-Lizenz. Details siehe LICENSE Datei.

🙏 致谢

---

ASMRoner — 每天晚上都有不同的妹妹陪你入睡 :)

最后更新:2026 年 2 月

--- Tranlated By Open Ai Tx | Last indexed: 2026-05-05 ---