亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? parse_metafile.c

?? linux下BT軟件的源碼。源代碼可以使用命令“make”進行編譯
?? C
字號:
#include <stdio.h>
#include <ctype.h>
#include <malloc.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include "parse_metafile.h"
#include "sha1.h"

char  *metafile_content = NULL; // 保存種子文件的內容
long  filesize;                 // 種子文件的長度

int       piece_length  = 0;    // 每個piece的長度,通常為256KB即262144字節
char      *pieces       = NULL; // 保存每個pieces的哈希值,每個哈希值為20字節
int       pieces_length = 0;    // pieces緩沖區的長度

int       multi_file    = 0;    // 指明是單文件還是多文件
char      *file_name    = NULL; // 對于單文件,存放文件名;對于多文件,存放目錄名
long long file_length   = 0;    // 存放待下載文件的總長度
Files     *files_head   = NULL; // 只對多文件種子有效,存放各個文件的路徑和長度

unsigned char info_hash[20];    // 保存info_hash的值,連接tracker和peer時使用
unsigned char peer_id[20];      // 保存peer_id的值,連接peer時使用

Announce_list *announce_list_head = NULL; // 用于保存所有tracker服務器的URL


int read_metafile(char *metafile_name)
{
	long  i;
	
	// 以二進制、只讀的方式打開文件
	FILE *fp = fopen(metafile_name,"rb");
	if(fp == NULL) {
		printf("%s:%d can not open file\n",__FILE__,__LINE__);
		return -1;
	}
	
	// 獲取種子文件的長度
	fseek(fp,0,SEEK_END);
	filesize = ftell(fp);
	if(filesize == -1) {
		printf("%s:%d fseek failed\n",__FILE__,__LINE__);
		return -1;
	}
	
	metafile_content = (char *)malloc(filesize+1);
	if(metafile_content == NULL) {
		printf("%s:%d malloc failed\n",__FILE__,__LINE__);
		return -1;
	}
	
	// 讀取種子文件的內容到metafile_content緩沖區中
	fseek(fp,0,SEEK_SET);
	for(i = 0; i < filesize; i++)
		metafile_content[i] = fgetc(fp);
	metafile_content[i] = '\0';

	fclose(fp); 

#ifdef DEBUG
	printf("metafile size is: %ld\n",filesize);
#endif	
	
	return 0;
}

int find_keyword(char *keyword,long *position)
{
	long i;

	*position = -1;
	if(keyword == NULL)  return 0;

	for(i = 0; i < filesize-strlen(keyword); i++) {
		if( memcmp(&metafile_content[i], keyword, strlen(keyword)) == 0 ) {
			*position = i;
			return 1;
		}
	}
	
	return 0;
}

int read_announce_list()
{
	Announce_list  *node = NULL;
	Announce_list  *p    = NULL;
	int            len   = 0;
	long           i;

	if( find_keyword("13:announce-list",&i) == 0 ) {
		if( find_keyword("8:announce",&i) == 1 ) {
			i = i + strlen("8:announce");
			while( isdigit(metafile_content[i]) ) {
				len = len * 10 + (metafile_content[i] - '0');
				i++;
			}
			i++;  // 跳過 ':'

			node = (Announce_list *)malloc(sizeof(Announce_list));
			strncpy(node->announce,&metafile_content[i],len);
			node->announce[len] = '\0';
			node->next = NULL;
			announce_list_head = node;
		}
	} 
	else {  // 如果有13:announce-list關鍵詞就不用處理8:announce關鍵詞
		i = i + strlen("13:announce-list");
		i++;         // skip 'l'
		while(metafile_content[i] != 'e') {
			i++;     // skip 'l'
			while( isdigit(metafile_content[i]) ) {
				len = len * 10 + (metafile_content[i] - '0');
				i++;
			}
			if( metafile_content[i] == ':' )  i++;
			else  return -1;

			// 只處理以http開頭的tracker地址,不處理以udp開頭的地址
			if( memcmp(&metafile_content[i],"http",4) == 0 ) {
				node = (Announce_list *)malloc(sizeof(Announce_list));
				strncpy(node->announce,&metafile_content[i],len);
				node->announce[len] = '\0';
				node->next = NULL;

				if(announce_list_head == NULL)
					announce_list_head = node;
				else {
					p = announce_list_head;
					while( p->next != NULL) p = p->next; // 使p指向最后個結點
					p->next = node; // node成為tracker列表的最后一個結點
				}
			}

			i = i + len;
			len = 0;
			i++;    // skip 'e'
			if(i >= filesize)  return -1;
		}	
	}

#ifdef DEBUG
	p = announce_list_head;
	while(p != NULL) {
		printf("%s\n",p->announce);
		p = p->next;
	}
#endif	
	
	return 0;
}

// 連接某些tracker時會返回一個重定向URL,需要連接該URL才能獲取peer
int add_an_announce(char *url)
{
	Announce_list *p = announce_list_head, *q;

	// 若參數指定的URL在tracker列表中已存在,則無需添加
	while(p != NULL) {
		if(strcmp(p->announce,url) == 0)  break;
		p = p->next;
	}
	if(p != NULL)  return 0;

	q = (Announce_list *)malloc(sizeof(Announce_list));
	strcpy(q->announce,url);
	q->next = NULL;
	
	p = announce_list_head;
	if(p == NULL)  { announce_list_head = q; return 1; }
	while(p->next != NULL)  p = p->next;
	p->next = q;
	return 1;
}

int is_multi_files()
{
	long i;

	if( find_keyword("5:files",&i) == 1 ) {
		multi_file = 1;
		return 1;
	}

#ifdef DEBUG
	// printf("is_multi_files:%d\n",multi_file);
#endif

	return 0;
}

int get_piece_length()
{
	long i;

	if( find_keyword("12:piece length",&i) == 1 ) {
		i = i + strlen("12:piece length");  // skip "12:piece length"
		i++;  // skip 'i'
		while(metafile_content[i] != 'e') {
			piece_length = piece_length * 10 + (metafile_content[i] - '0');
			i++;
		}
	} else {
		return -1;
	}

#ifdef DEBUG
	printf("piece length:%d\n",piece_length);
#endif

	return 0;
}

int get_pieces()
{
	long i;

	if( find_keyword("6:pieces", &i) == 1 ) {
		i = i + 8;     // skip "6:pieces"
		while(metafile_content[i] != ':') {
			pieces_length = pieces_length * 10 + (metafile_content[i] - '0');
			i++;
		}
		i++;           // skip ':'
		pieces = (char *)malloc(pieces_length+1);
		memcpy(pieces,&metafile_content[i],pieces_length);
		pieces[pieces_length] = '\0';
	} else {
		return -1;
	}

#ifdef DEBUG
	printf("get_pieces ok\n");
#endif

	return 0;
}

int get_file_name()
{
	long  i;
	int   count = 0;

	if( find_keyword("4:name", &i) == 1 ) {
		i = i + 6;  // skip "4:name"
		while(metafile_content[i] != ':') {
			count = count * 10 + (metafile_content[i] - '0');
			i++;
		}
		i++;        // skip ':' 
		file_name = (char *)malloc(count+1);
		memcpy(file_name,&metafile_content[i],count);
		file_name[count] = '\0';
	} else {
		return -1;
	}

#ifdef DEBUG
	// 由于可能含有中文字符,因此可能打印出亂碼
	// printf("file_name:%s\n",file_name);
#endif

	return 0;
}

int get_file_length()
{
	long i;

	if(is_multi_files() == 1)  {
		if(files_head == NULL)  get_files_length_path();
		Files *p = files_head;
		while(p != NULL) { file_length += p->length; p = p->next; }
	} else {
		if( find_keyword("6:length",&i) == 1 ) {
			i = i + 8;  // skip "6:length"
			i++;        // skip 'i' 
			while(metafile_content[i] != 'e') {
				file_length = file_length * 10 + (metafile_content[i] - '0');
				i++;
			}	
		}
	}
	
#ifdef DEBUG
	printf("file_length:%lld\n",file_length);
#endif

	return 0;
}

int get_files_length_path()
{
	long   i;
	int    length;
	int    count;
	Files  *node  = NULL;
	Files  *p     = NULL;

	if(is_multi_files() != 1) {
		return 0;
	}
	
	for(i = 0; i < filesize-8; i++) {
		if( memcmp(&metafile_content[i],"6:length",8) == 0 )
		{
			i = i + 8;  // skip "6:length"
			i++;        // skip 'i' 
			length = 0;
			while(metafile_content[i] != 'e') {
				length = length * 10 + (metafile_content[i] - '0');
				i++;
			}
			node = (Files *)malloc(sizeof(Files));
			node->length = length;
			node->next = NULL;
			if(files_head == NULL)
				files_head = node;
			else {
				p = files_head;
				while(p->next != NULL) p = p->next;
				p->next = node;
			}
		}
		if( memcmp(&metafile_content[i],"4:path",6) == 0 )
		{
			i = i + 6;  // skip "4:path"
			i++;        // skip 'l'
			count = 0;
			while(metafile_content[i] != ':') {
				count = count * 10 + (metafile_content[i] - '0');
				i++;
			}
			i++;        // skip ':'
			p = files_head;
			while(p->next != NULL) p = p->next;
			memcpy(p->path,&metafile_content[i],count);
			*(p->path + count) = '\0';
		}
	}

#ifdef DEBUG
	// 由于可能含有中文字符,因此可能打印出亂碼
	// p = files_head;
	// while(p != NULL) {
	//	 printf("%ld:%s\n",p->length,p->path);
	//	 p = p->next;
	// }
#endif

	return 0;
}

int get_info_hash()
{
	int   push_pop = 0;
	long  i, begin, end;

	if(metafile_content == NULL)  return -1;

	if( find_keyword("4:info",&i) == 1 ) {
		begin = i+6;  // begin是關鍵字"4:info"對應值的起始下標
	} else {
		return -1;
	}

	i = i + 6;        // skip "4:info"
	for(; i < filesize; )
		if(metafile_content[i] == 'd') { 
			push_pop++;
			i++;
		} else if(metafile_content[i] == 'l') {
			push_pop++;
			i++;
		} else if(metafile_content[i] == 'i') {
			i++;  // skip i
			if(i == filesize)  return -1;
			while(metafile_content[i] != 'e') {
				if((i+1) == filesize)  return -1;
				else i++;
			}
			i++;  // skip e
		} else if((metafile_content[i] >= '0') && (metafile_content[i] <= '9')) {
			int number = 0;
			while((metafile_content[i] >= '0') && (metafile_content[i] <= '9')) {
				number = number * 10 + metafile_content[i] - '0';
				i++;
			}
			i++;  // skip :
			i = i + number;
		} else if(metafile_content[i] == 'e') {
			push_pop--;
			if(push_pop == 0) { end = i; break; }
			else  i++; 
		} else {
			return -1;
		}
	if(i == filesize)  return -1;

	SHA1_CTX context;
	SHA1Init(&context);
	SHA1Update(&context, &metafile_content[begin], end-begin+1);
	SHA1Final(info_hash, &context);

#ifdef DEBUG
	printf("info_hash:");
	for(i = 0; i < 20; i++)  
		printf("%.2x ",info_hash[i]);
	printf("\n");
#endif

	return 0;
}

int get_peer_id()
{
	// 設置產生隨機數的種子
	srand(time(NULL));
	// 生成隨機數,并把其中12位賦給peer_id,peer_id前8位固定為-TT1000-
	sprintf(peer_id,"-TT1000-%12d",rand());

#ifdef DEBUG
	int i;
	printf("peer_id:");
	for(i = 0; i < 20; i++)  printf("%c",peer_id[i]);
	printf("\n");
#endif

	return 0;
}

void release_memory_in_parse_metafile()
{
	Announce_list *p;
	Files         *q;
	
	if(metafile_content != NULL)  free(metafile_content);
	if(file_name != NULL)         free(file_name);
	if(pieces != NULL)            free(pieces);
	
	while(announce_list_head != NULL) {
		p = announce_list_head;
		announce_list_head = announce_list_head->next;
		free(p);
	}

	while(files_head != NULL) {
		q = files_head;
		files_head = files_head->next;
		free(q);
	}
}

int parse_metafile(char *metafile)
{
	int ret;

	// 讀取種子文件
	ret = read_metafile(metafile);
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }
	
	// 從種子文件中獲取tracker服務器的地址
	ret = read_announce_list();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }

	// 判斷是否為多文件
	ret = is_multi_files();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }
	
	// 獲取每個piece的長度,一般為256KB
	ret = get_piece_length();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }
	
	// 讀取各個piece的哈希值
	ret = get_pieces();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }
	
	// 獲取要下載的文件名,對于多文件的種子,獲取的是目錄名
	ret = get_file_name();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }

	// 對于多文件的種子,獲取各個待下載的文件路徑和文件長度
	ret = get_files_length_path();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }
	
	// 獲取待下載的文件的總長度
	ret = get_file_length();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }

	// 獲得info_hash,生成peer_id
	ret = get_info_hash();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }
	ret = get_peer_id();
	if(ret < 0) { printf("%s:%d wrong",__FILE__,__LINE__); return -1; }

	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
人人超碰91尤物精品国产| 亚洲一区成人在线| 日韩精品五月天| 欧美视频一区二区三区四区| 欧美一区午夜精品| 欧美一级一级性生活免费录像| 99久久精品国产一区| 一区二区三区欧美| 首页综合国产亚洲丝袜| 欧美一区二区三区小说| 韩国精品一区二区| 国产精品午夜在线| 国产麻豆精品95视频| 国产精品天干天干在线综合| 色欲综合视频天天天| 亚洲自拍与偷拍| 欧美一区二区不卡视频| 国产成都精品91一区二区三| 日韩毛片在线免费观看| 91在线小视频| 亚洲美女偷拍久久| 欧美久久久久久蜜桃| 激情综合色丁香一区二区| 久久免费午夜影院| 91福利资源站| 国产一区二区免费看| 亚洲天堂久久久久久久| 欧美人妖巨大在线| 99久久精品国产麻豆演员表| 亚洲国产精品视频| 中文欧美字幕免费| 色www精品视频在线观看| 国产精品看片你懂得| 亚洲伦理在线免费看| 欧洲一区二区三区在线| 狠狠久久亚洲欧美| 国产精品护士白丝一区av| 久久成人麻豆午夜电影| 美国三级日本三级久久99| 国内一区二区视频| 国产日本欧洲亚洲| 亚洲国产成人私人影院tom| 欧美三级三级三级| 五月激情综合网| 久久精品国产亚洲aⅴ| 日本一区二区三区高清不卡| 91 com成人网| 亚洲欧美日韩国产综合在线| 中文字幕人成不卡一区| 五月激情六月综合| 中文成人av在线| 日韩久久一区二区| 精品欧美久久久| 欧美亚洲自拍偷拍| 韩国精品久久久| 国产喷白浆一区二区三区| 麻豆成人久久精品二区三区小说| 久久精品亚洲乱码伦伦中文| 国产美女视频91| 国产欧美日韩中文久久| 在线视频中文字幕一区二区| 成人午夜av电影| 国产福利精品一区| 麻豆91小视频| 久久精品国产成人一区二区三区| 丰满白嫩尤物一区二区| 久久亚洲精品小早川怜子| 日韩影视精彩在线| 欧美精品一区二| 丝袜美腿高跟呻吟高潮一区| 欧美综合天天夜夜久久| 国产一区免费电影| 高清不卡一区二区在线| 91猫先生在线| 亚洲成人av免费| 成人免费观看av| 日韩欧美一卡二卡| 欧美成人官网二区| 精品福利视频一区二区三区| 日韩理论片在线| 奇米影视一区二区三区小说| 91成人免费在线视频| 91精品国产综合久久小美女| 久久精品国产99久久6| 国内精品免费在线观看| 亚洲va欧美va国产va天堂影院| 国产乱码精品一品二品| 麻豆精品新av中文字幕| 国产制服丝袜一区| 婷婷久久综合九色综合伊人色| 久久电影国产免费久久电影| 欧美日韩国产精品成人| 国产美女一区二区| 亚洲成人高清在线| 91老师国产黑色丝袜在线| 欧美国产禁国产网站cc| 成人黄色在线看| 亚洲欧美一区二区视频| 亚洲国产成人高清精品| 欧美日韩专区在线| 一区二区三区高清| 日韩在线a电影| 欧美视频中文字幕| www.在线欧美| 成人午夜在线播放| 91精品久久久久久久99蜜桃 | 国产精品久久久久久久久搜平片| 成人永久免费视频| 亚洲自拍另类综合| 欧美欧美午夜aⅴ在线观看| 国产一区二区不卡| 麻豆久久一区二区| 亚洲人成精品久久久久久| 在线看国产日韩| 国内精品第一页| 亚洲精选一二三| 亚洲精品一区二区在线观看| 国产99久久久精品| 午夜精品福利一区二区蜜股av| 精品成人佐山爱一区二区| 91蜜桃在线免费视频| 久久66热偷产精品| 亚洲一区二区三区在线| 久久久青草青青国产亚洲免观| 色噜噜狠狠一区二区三区果冻| 全国精品久久少妇| 国产精品久线在线观看| 欧美一个色资源| 91在线码无精品| 国产在线播放一区| 亚洲bt欧美bt精品| 国产精品卡一卡二卡三| 精品三级在线观看| 欧美人体做爰大胆视频| 91网站最新地址| 国产精品羞羞答答xxdd| 奇米精品一区二区三区在线观看 | 亚洲综合在线视频| 国产日韩影视精品| 日韩一级成人av| 欧美日韩国产乱码电影| 99re6这里只有精品视频在线观看| 亚洲国产精品欧美一二99 | 波多野洁衣一区| 国产一区二区电影| 久久国产精品99久久久久久老狼 | 久久机这里只有精品| 亚洲第一狼人社区| 亚洲精品国产精品乱码不99| 国产亚洲成aⅴ人片在线观看 | 亚洲欧洲韩国日本视频| 91精品国产乱码| 日韩视频免费直播| 欧美一区二区观看视频| 欧美一卡2卡三卡4卡5免费| 99视频精品免费视频| 夫妻av一区二区| 成人一区二区三区| 福利一区福利二区| 成人av在线资源网| 色综合视频一区二区三区高清| 成人黄色综合网站| av电影在线观看完整版一区二区| 国产精品69毛片高清亚洲| 国产传媒日韩欧美成人| 成人高清视频免费观看| 91免费观看在线| 欧美视频完全免费看| 色综合视频在线观看| 欧美日韩不卡在线| 欧美一级生活片| 久久婷婷一区二区三区| 中文天堂在线一区| 亚洲成a天堂v人片| 狠狠色丁香久久婷婷综合丁香| 国产成都精品91一区二区三| 色综合久久综合| 69堂精品视频| 国产偷v国产偷v亚洲高清| 国产精品欧美极品| 亚洲同性gay激情无套| 亚洲高清视频中文字幕| 久草中文综合在线| 99免费精品在线观看| 欧美老人xxxx18| 2017欧美狠狠色| 最新国产成人在线观看| 日韩国产在线一| 国产剧情在线观看一区二区| 91在线观看视频| 欧美一区二区大片| 专区另类欧美日韩| 黄色精品一二区| 在线视频欧美区| 久久青草欧美一区二区三区| 亚洲自拍都市欧美小说| 国产成人精品网址| 91精品国产91热久久久做人人| 亚洲国产成人在线| 狠狠色综合日日|