我正在尝试使用 libtorrent-rasterbar 0.16.13 的非 DHT、仅跟踪器行为下载远程元数据文件 (.torrent)。
不幸的是,我收到了很多 peer_disconnected 错误;从我的程序中播种并通过 BT 或 QBittorrent 等客户端下载。
我正在使用十六进制编码的哈希,我不知道这是否是问题,因为 libtorrent-rasterbar 似乎在 Magnet URI 中支持 Hex 和 Base32 哈希。
请记住,我已经有一个跟踪器并且我不想使用 DHT,但磁铁只是用于将远程种子下载到我的本地文件系统。
这是我的 AddMagnetLink 代码:
RESULT SessionManager::addMagnetLink(const QString& info_hash,
const QString& torrentPath,
libtorrent::torrent_handle &thndl)
{
try
{
libtorrent::add_torrent_params tp;
boost::filesystem::path path(torrentPath.toStdWString());
std::string url;
url.append("magnet:?xt=urn:btih:");
url.append(info_hash.toStdString());
url.append("&tr=udp://tracker.publicbt.com:80");
qDebug() << "Using magnet URI: "<< url.c_str();
qDebug() << "Save path is " << tp.save_path.c_str();
tp.paused = false;
tp.auto_managed = true;
tp.save_path = path.string();
libtorrent::error_code ec;
thndl = libtorrent::add_magnet_uri(*_lt_session, url, tp,ec);
qDebug() << "add_torrent error_code = " << ec.message().c_str();
qDebug() << "Has metadata";
}
catch (std::exception& e)
{
qWarning() << "(!) Exception thrown: " << e.what();
return NKT_E_FAIL;
}
return S_OK;
}
示例输出:
peer_disconnected_alert: 8061b09e2229111ed93a48080835e371c89c1111 peer (1xx.1xx.3x.x5, libtorrent 0.16.0) disconnecting: [libtorrent error] connected to ourselves
peer_disconnected_alert: 8061b09e2229111ed93a48080835e371c89c1111 peer (1xx.1xx.3x.x5, Unknown) disconnecting: [asio.misc] End of file
我在我的机器之间的本地局域网中尝试这个。
编辑:(添加更多数据)
令人惊讶的是,这仅发生在元数据传输中,因为我尝试使用普通的 torrent 文件并且它可以工作(种子和下载)。我启用了 metadata_transfer 和 ut_metadata 扩展;此外,还启用了 DHT、PEX、UPNP、NATPMP 和本地发现。传输元数据似乎存在一些问题。
提前致谢。,