📖 Introdução ao Projeto
ASMRoner é uma ferramenta de linha de comando em Go para pesquisar, baixar, sincronizar obras de áudio do asmr.one e oferece uma interface web simples para reprodução.
🌐 Projeto derivado: asmr.furina.in — Uma página online simples e limpa para ouvir ASMR
🚀 Início Rápido
https://github.com/MIKANOoOo/asmr-downloader.git && cd asmroner
go build -o asmroner
./asmroner config # 交互式初始化配置📋 Comandos Comuns
# 搜索
./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📸 Capturas de Tela
| Configuração | Pesquisa |
|:---:|:---:|
|
|
|
| Download | Sincronização |
|
|
|
| Download Sincronizado | Estatísticas |
|
|
|
| Interface Web | Interface Web 2 |
|
|
|
| Interface exportar | Interface exportar 2 |
|
|
|
✨ Funcionalidades
- Pesquisa: Pesquisa única/em lote por RJID, sintaxe de pesquisa avançada, exportação de resultados em CSV/JSON
- Download: Download único/em lote/dos mais populares, limitação automática, tentativas automáticas, recuo exponencial
- Sincronização: Sincronização de metadados, controle de download em lote, rastreamento de status, tentativas automáticas de falha
- Interface Web: Navegação visual, reprodução no navegador, design responsivo
- Configuração: Inicialização interativa, suporte a proxy, limitação, jitter e outras configurações avançadas
⚙️ Explicação do Arquivo de Configuração
Caminho do arquivo de configuração: ~/.asmroner/config.toml (formato TOML)
[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
📋 Consulta rápida de opções de comando
| Comando | Opção | Descrição |
|---------|-------|-----------|
| search | -c | Quantidade de resultados da pesquisa (padrão 10) |
| search download | -d, -s | Diretório de download, quantidade de downloads |
| search export | -f, -n | Nome do arquivo exportado (.csv/.json), quantidade exportada |
| download | -d, -n | Diretório de download, quantidade hot100 |
| sync download | -d | Diretório de download |
| sync retry | -d | Diretório dos arquivos com falha |
| sync export | -s, -f | Status (failed/success), arquivo exportado |
| listen | -p | Porta (padrão 9999) |
| export | -o, -n | Diretório exportado, quantidade hot100 |
📁 Estrutura do projeto
asmroner/
├── cmd/ # 命令行接口(config/download/search/sync/listen)
├── internal/
│ ├── engine/ # 核心下载引擎(限流、重试、并发控制)
│ ├── logger/ # 结构化日志系统
│ ├── model/ # 数据模型与查询参数解析
│ ├── database/ # SQLite 数据库
│ ├── consts/ # 常量定义
│ └── utils/ # 工具函数
├── webui/ # 内嵌 Web 界面(Tailwind + Plyr)
├── main.go
└── go.mod
🛠 Stack Tecnológico
| Componente | Uso | |------|------| | Cobra + Viper | Framework CLI + Gerenciamento de Configuração | | GORM + SQLite | Persistência de Dados | | Resty | Cliente HTTP (suporta proxy HTTP/SOCKS5) | | Pond | Pool de Trabalho Concorrente | | x/time/rate | Limitação de taxa por token bucket | | Gin | Serviço Web | | Tailwind + Plyr | Interface Front-end + Reprodução de Áudio |
🔧 Perguntas Frequentes
Arquivo de configuração não encontrado → Execute ./asmroner config para inicializar
Falha no download (stream error) → O programa tentará novamente automaticamente; se ainda falhar, use sync retry ou verifique .asmroner-data/download_errors.log
Interface web inacessível → Certifique-se de que a porta não está em uso, tente especificar outra porta com -p
Resultados de busca vazios → Verifique a sintaxe da consulta e tente simplificar as condições
Método de download para o comando export → Consulte o guia
🤝 Contribuição
Pull Requests são bem-vindos! Faça um fork → crie um novo branch → envie alterações → abra um PR.
📄 Licença
Este projeto adota a licença MIT, veja mais detalhes no arquivo LICENSE.
🙏 Agradecimentos
- Agradecimento especial ao go-asmr-spider
- Obrigado a todos os colaboradores e usuários!
ASMRoner — Toda noite uma menina diferente para te acompanhar até o sono :)
Última atualização: fevereiro de 2026
--- Tranlated By Open Ai Tx | Last indexed: 2026-05-05 ---