c语言 - 为什么跟踪器服务器发送"x03r.opConnection ID missmatch."作为响应消息?(比特流协议)



我正在尝试实现Bittorrent客户端。但我很难与跟踪器服务器进行通信。它不会发送Bencoded字典作为对我请求的回应
它总是发送以下字符串作为响应。

"x03r.opConnection ID missmatch."

这是torrent元文件的子字符串。

d8:announce38:udp://tracker.publicbt.com:80/announce13:announce-
listll38:udp://tracker.publicbt.com:80/announceel
44:udp://tracker.openbittorrent.com:80/announceel
43:udp://fr33domtracker.h33t.com:3310/announceel
35:udp://tracker.istole.it:80/announceel
37:http://fr33dom.h33t.com:3310/announceel
36:udp://fr33dom.h33t.com:3310/announceee
7:comment61:Torrent downloaded from torrent cache at http://torcache.net/
10:created by13:uTorrent/330013:creation datei1372123476e8:encoding
5:UTF-8
4:infod13:file-durationli207ee10:file-mediali0ee6:lengthi59625855e4:name
7:Owl.mp412:piece lengthi65536e

我向跟踪器服务器发送以下消息,以便获得对等方列表。

udp://tracker.openbittorrent.com:80/announce?info_hash=%%73%%78%%b1%%df%%32%%7c%%78%%0f%%d2%%90%%59%%b8%%0c%%03%%bd%%62%%0f%%45%%af%%26
&left=0
&uploaded=0
&port=6882
&event=started

这是我的代码,它将请求发送到跟踪器服务器,然后收到一个尴尬的响应。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include <errno.h>
#define BUFSIZE 1024
int main( int argc, char** argv )
{
    int sockfd, portno, n;
    struct sockaddr_in serveraddr;
    struct hostent *server;
    char buf[BUFSIZE];
    portno      =   80;
    /* socket: create the socket */
    sockfd = socket(AF_INET, SOCK_DGRAM, 0);
    if (sockfd < 0)
    {
        fprintf(stderr, "socket errorn");
        exit(0);
    }
    server = gethostbyname("tracker.openbittorrent.com");
    printf("%sn", inet_ntoa( *(struct in_addr*)server->h_addr_list[0]));
    /* build the server's Internet address */
    bzero((char *) &serveraddr, sizeof(serveraddr));
    serveraddr.sin_family           =   AF_INET;
    serveraddr.sin_addr.s_addr      =   inet_addr( inet_ntoa( *(struct in_addr*)server->h_addr_list[0]) );
    serveraddr.sin_port             =   htons(portno);
    /* connect: create a connection with the server */
    if (connect(sockfd, (struct sockaddr *)&serveraddr, sizeof(serveraddr)) < 0)
    {
        printf("error : %dn", errno);
        fprintf(stderr, "connect errorn");
        exit(0);
    }
    /* generate request message into buffer pointed by buf. */
    sprintf(buf,    "udp://tracker.openbittorrent.com:80/announce"
                    "?info_hash=%%73%%78%%b1%%df%%32%%7c%%78%%0f%%d2%%90%%59%%b8%%0c%%03%%bd%%62%%0f%%45%%af%%26"
                    "&left=0"
                    "&uploaded=0"
                    "&ip=0"
                    "&key=0"
                    "&port=6882"
                    "&event=started"
                    );
    /* write: send the request to the tracker server */
    n = write(sockfd, buf, strlen(buf));
    if (n < 0)
    {
        fprintf(stderr, "fail to send your request.n");
        exit(0);
    }
    memset(buf, 0x00, sizeof(buf));
    n = read(sockfd, buf, BUFSIZE);
    printf("%sn", buf + 4);
    close(sockfd);
    return 0;
}

附件是torrent文件
附加

首先,您要向使用完全不同协议的UDP跟踪器发送http请求
请参阅:http://www.bittorrent.org/beps/bep_0015.html

其次,info_hash的URL编码是错误的
它看起来像这样:

info_hash=%%73%%78%%b1%%df%%32%%7c%%78%%0f%%d2%%90%%59%%b8%%0c%%03%%bd%%62%%0f%%45%%af%%26

它应该是这样的:

info_hash=%0C%7Dr%CAQvQf%10%80%CBB%07%3DT_%24%3C%F8%2C

第三,您需要将"compact=1"添加到请求字符串中
请参阅:为什么跟踪器服务器不理解我的请求?(Bittorrent协议)

试用:

http://exodus.desync.com:6969/announce?info_hash=%0C%7Dr%CAQvQf%10%80%CBB%07%3DT_%24%3C%F8%2C&left=0&uploaded=0&port=6882&event=started&compact=1

跟踪器将回答:

d8:completei1e10:downloadedi0e10:incompletei0e8:intervali1720e12:min intervali860e5:peers6:******e

最新更新