从tracker上获取peer列表[通俗易懂]

从tracker上获取peer列表[通俗易懂] 从torrent文件中得到了tracker列表后,接下来的工作就是获取peer列表.tracker使用http协议.客户端向服务器发送标准的GET请求,就可以得到这个列表.tracker返回的信息是bencode编码.向tracker发送的GET请求有如下一些参数:info_hash(必须):    torrent文件中info字段的sha1.torrent文件解析器中已经计算此值,保存在CTo

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
 从torrent文件中得到了tracker列表后,接下来的工作就是获取peer列表.

tracker使用http协议.客户端向服务器发送标准的GET请求,就可以得到这个列表.tracker返回的信息是bencode编码.

向tracker发送的GET请求有如下一些参数:

info_hash(必须):

    torrent文件中info字段的sha1.
torrent文件解析器中已经计算此值,保存在CTorrentParser的m_Infohash成员中.

peer_id(必须):

    节点ID,长20字节.通常每一个下载产生一个相应的ID.通过peer_id可以识别大多数客户端类型.

ip(可选):

    客户端指定的期望其他节点与本地交互时连接的IP.一般来说不用指定此参数,除非客户端使用了代理或者端口映射.

port(可选):

    本地侦听的端口.

uploaded:

    已经上传的字节数.

download:

    已经下载的字节数.

left:

    未下载的字节数.

event(可选):

    此参数可以是如下的值:

        started:下载开始

        completed:下载完毕

        stopped:下载停止

compact(可选):

    此参数值为1,表示期望得到紧凑模式的节点列表.

    否则表示期望得到普通模式的节点列表.    

no_peer_id(可选):

        其值为1,表示不需要节点id信息.

通常tracker会返回错误代码200.

如果返回的bencode编码中包含failure reason字段,则表示处理请求失败,此字段的值即为失败原因.

如果请求成功,则有两个字段是必须出现的:

    peers:节点列表

    interval:服务器期望的下次查询间隔时间,单位为秒

通常还会有如下一些字段出现:

    done peers:下载完毕的节点个数

    num peers或者incomplete: 当前下载的节点个数

普通模式的回复其peers字段包括ip,port两个字段,如果未指定no_peer_id参数还将包括peer id字段.

下面是普通模式的回复例子:

        d8:intervali3600e5:peersld2:ip13:192.168.24.527:peer id20:{peer_id}4:porti2001eed2:ip11:192.168.0.37:peer id20:{peer_id}4:porti6889eeee

        d8:intervali3600e5:peersld2:ip13:192.168.24.524:porti2001eed2:ip11:192.168.0.34:porti6889eeee

紧凑模式的回复其peers字段是一个如下结构的数组:

         struct PEER

        {

             DWORD  IP;//节点IP

             WORD  Port;//节点端口

        }; 

        例如:192.168.24.52:2001 => 0xC0 0xA8 0x18 0x34 0xD1 0x07

下面是紧凑模式的回复例子:

         d8:intervali3600e5:peers12:{12 characters of binary data}e


逸搜(EaseSo)论坛有一个从tracker获取peer列表的
测试程序BTTrackerTest

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189162.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • nginx转发其他网站_nginx搭建网站

    nginx转发其他网站_nginx搭建网站方式一location=/pospal-api2/openapi/v1/orderOpenApi/addOnLineOrder{proxy_passhttps://openapi5.pospal.cn/openinterface/orderOpenApi/addOnLineOrder;}方式二

    2022年10月18日
    2
  • stm32使用oled显示屏_stm32f103c8t6封装

    stm32使用oled显示屏_stm32f103c8t6封装stm32f103c8t6控制OLED显示屏0.96寸4针OLED显示屏IIC蓝色0.96寸OLED显示屏7针SPI蓝色,6针黄蓝双色0.96寸4针OLED显示屏IIC蓝色话不多说,直接先上图!显然可以看出,利用IIC接口显示出来的文字是没那么清晰的,有点断断续续的。而这款显示屏我是买淘宝上这家店的,下面附上这个显示屏链接:0.96寸4针OLED显示屏IIC蓝色附上显示屏与stm32的接线://功能描述:OLEDI2C接口演示例程(STM32F103系列)//

    2022年10月15日
    2
  • JVM垃圾回收器_jdk6默认垃圾回收器

    JVM垃圾回收器_jdk6默认垃圾回收器JVM垃圾回收器垃圾回收器分类说明垃圾回收器工作原理垃圾回收器分类说明如果说垃圾回收算法是内存回收的方法论,那么垃圾回收器就是内存回收的具体实现,下图展示了7中作用于不同分代的收集器。其中用于新生代的回收器包括Serial,PraNew,ParallelScavenge,回收老年代的收集器包括SerialOld,Parallelold,CMS,还有作用于回收整个java堆的G1收集器,不同收集器之间的连线表示他们可以搭配使用。Serial收集器(复制算法):新生代单线程收集器,标记和清理

    2025年10月28日
    3
  • GBDT算法

    GBDT算法

    2021年11月19日
    52
  • Xray扫描器[通俗易懂]

    Xray扫描器[通俗易懂]简介xray是一款可以使用HTTP/HTTPS代理进行被动扫描的安全工具,支持功能如下独立的URL扫描 基于HTTP的被动代理扫描,同时支持HTTPS SQL注入检测模块 命令注入检测模块 任意重定向检测模块 路径遍历模块Xray扫描器内置插件XSS漏洞检测(key:xss):利用语义分析的方式检测XSS漏洞 SQL注入检测(key:sqldet…

    2022年5月30日
    186
  • js根据对象删除本身元素

    js根据对象删除本身元素functiondel e varmy document getElementBy a varmy e parent 0 nbsp nbsp if my null nbsp nbsp nbsp nbsp my parentNode removeChild my 1 第一种可以根据 id 获取当前元素 然后进行删除 2 第二种可以根据子元素 进行寻找到

    2025年8月22日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号