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

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

?? graph.c

?? linux下流量查看軟件,可以查看到每臺機子的具體流量
?? C
?? 第 1 頁 / 共 3 頁
字號:
#include <unistd.h>#include <setjmp.h>#include <signal.h>#include <string.h>#include <netdb.h>#include <netinet/in.h>#include <sys/types.h>#include <sys/socket.h>#include <time.h>#include "bandwidthd.h"#ifdef HAVE_ARPA_NAMESER_H#include <arpa/nameser.h>#endif#ifdef HAVE_RESOLV_H#include <resolv.h>#endifextern unsigned int SubnetCount;extern struct config config;jmp_buf dnsjump;static void rdnslngjmp(int signal);void rdns(char *Buffer, unsigned long IP)  // This takes over sigalarm!	{#ifdef HAVE_RESOLV_H	char DNSError[] = "DNS Timeout: Correct to speed up graphing";	char None[] = "Configure DNS to reverse this IP";	char TooManyDNSTimeouts[] = "Too many dns timeouts, reverse lookups suspended";	struct hostent *hostent;	char chrIP[50];	static int Init = TRUE;	static int DNSTimeouts = 0;  // This is reset for each run because we're forked	unsigned long addr = htonl(IP);    _res.retrans = 1;    _res.retry = 2;	if (Init)		{        signal(SIGALRM, rdnslngjmp);		Init = FALSE;		}	if (DNSTimeouts > 100)		{		syslog(LOG_ERR, "Too many dns timeouts, reverse lookups suspended");        strncpy(Buffer, TooManyDNSTimeouts, 253);		Buffer[254] = '\0';		return;		}			if (setjmp(dnsjump) == 0)		{		alarm(10);  // Don't let gethostbyaddr hold us up too long		hostent = gethostbyaddr((char *) &addr, 4, AF_INET); // (char *)&Data->IP						alarm(0);				if (hostent)			sprintf(Buffer, "%s", hostent->h_name);		else			{	        strncpy(Buffer, None, 253);			Buffer[254] = '\0';			}		}	else  // Our alarm timed out		{		HostIp2CharIp(IP, chrIP);		syslog(LOG_ERR, "DNS timeout for %s: This problem reduces graphing performance", chrIP);		DNSTimeouts++;        strncpy(Buffer, DNSError, 253);		Buffer[254] = '\0';		}#else	Buffer[0] = '\0';#endif	}static void rdnslngjmp(int signal)	{    longjmp(dnsjump, 1);	}void swap(struct SummaryData **a, struct SummaryData **b) {	struct SummaryData *temp;    temp = *a; *a = *b; *b = temp;}void QuickSortSummaryData(struct SummaryData *SummaryData[], int left, int right) {    int i,j,center;    unsigned long long pivot;    if (left==right) return;    if (left+1==right) {        if (SummaryData[left]->Total < SummaryData[right]->Total)            swap(&SummaryData[left],&SummaryData[right]);        return;    }    /* use the median-of-three method for picking pivot */    center = (left+right)/2;    if (SummaryData[left]->Total < SummaryData[center]->Total)        swap(&SummaryData[left],&SummaryData[center]);    if (SummaryData[left]->Total < SummaryData[right]->Total)        swap(&SummaryData[left],&SummaryData[right]);    if (SummaryData[center]->Total < SummaryData[right]->Total)        swap(&SummaryData[center],&SummaryData[right]);    pivot = SummaryData[center]->Total;    swap(&SummaryData[center],&SummaryData[right-1]); /* hide the pivot */    i = left; j = right - 1;    do {        do { ++i; } while (SummaryData[i]->Total > pivot);        do { --j; } while (SummaryData[j]->Total < pivot);        swap(&SummaryData[i],&SummaryData[j]);    } while (j > i);    swap(&SummaryData[i],&SummaryData[j]); /* undo last swap */    swap(&SummaryData[i],&SummaryData[right-1]); /* restore pivot */    QuickSortSummaryData(SummaryData,left,i-1);    QuickSortSummaryData(SummaryData,i+1,right);}#define NumFactor 1024static void FormatNum(unsigned long long n, char *buf, int len) {    double f;    if (n<NumFactor) { snprintf(buf,len,"<td align=\"right\"><tt>%i&nbsp;</tt></td>",(int)n); return; }    f = n;    f /= NumFactor; if (f<NumFactor) { snprintf(buf,len,"<td align=\"right\"><tt>%.1fK</tt></td>",f); return; }    f /= NumFactor; if (f<NumFactor) { snprintf(buf,len,"<td align=\"right\"><tt>%.1fM</tt></td>",f); return; }    f /= NumFactor; if (f<NumFactor) { snprintf(buf,len,"<td align=\"right\"><tt>%.1fG</tt></td>",f); return; }    f /= NumFactor; snprintf(buf,len,"<td align=\"right\"><tt>%.1fT</tt></td>\n",f);}void PrintTableLine(FILE *stream, struct SummaryData *Data, int Counter)	{	char Buffer1[50];	char Buffer2[50];	char Buffer3[50];	char Buffer4[50];	char Buffer4b[50];	char Buffer5[50];	char Buffer5b[50];	char Buffer6[50];	char Buffer7[50];	char Buffer8[50];	// First convert the info to nice, human readable stuff	if (Data->IP == 0)		strcpy(Buffer1, "Total");	else		HostIp2CharIp(Data->IP, Buffer1);    FormatNum(Data->Total,         Buffer2,  50);	FormatNum(Data->TotalSent,     Buffer3,  50);	FormatNum(Data->TotalReceived, Buffer4,  50);	FormatNum(Data->FTP, 		   Buffer4b, 50);	FormatNum(Data->HTTP,          Buffer5,  50);	FormatNum(Data->P2P,           Buffer5b, 50);	FormatNum(Data->TCP,           Buffer6,  50);	FormatNum(Data->UDP,           Buffer7,  50);	FormatNum(Data->ICMP,          Buffer8,  50);	if (Counter%4 == 0 || (Counter-1)%4 == 0)		fprintf(stream, "<TR>");	else		fprintf(stream, "<TR bgcolor=lightblue>");	if (Data->Graph)		fprintf(stream, "<TD><a href=\"#%s-%c\">%s</a></TD>%s%s%s%s%s%s%s%s%s</TR>\n",			Buffer1, // Ip			config.tag,			Buffer1, // Ip			Buffer2, // Total			Buffer3, // TotalSent			Buffer4, // TotalReceived			Buffer4b, // FTP			Buffer5, // HTTP			Buffer5b, // P2P			Buffer6, // TCP			Buffer7, // UDP			Buffer8); // ICMP	else		fprintf(stream, "<TD>%s</TD>%s%s%s%s%s%s%s%s%s</TR>\n",			Buffer1, // Ip			Buffer2, // Total			Buffer3, // TotalSent			Buffer4, // TotalReceived			Buffer4b, // FTP			Buffer5, // HTTP			Buffer5b, // P2P					Buffer6, // TCP			Buffer7, // UDP			Buffer8); // ICMP	}void MakeIndexPages(int NumIps, struct SummaryData *SummaryData[])	{	int SubnetCounter;	int Counter, tCounter;	time_t WriteTime;	char filename[] = "./htdocs/index2.html";	char *PeriodDesc;		FILE *file;	char Buffer1[50];	char Buffer2[50];	char HostName[255];	WriteTime = time(NULL);		QuickSortSummaryData(SummaryData, 0, NumIps-1);	////////////////////////////////////////////////	// Print main index page		if (config.tag == '1')		{		if ((file = fopen("./htdocs/index.html", "wt")) == NULL)			{			syslog(LOG_ERR, "Failed to open ./htdocs/index.html");			exit(1);			}		}	else		{		filename[14] = config.tag;		if ((file = fopen(filename, "wt")) == NULL)			{			syslog(LOG_ERR, "Failed to open %s", filename);			exit(1);			}		}	switch (config.tag)		{		case '1': PeriodDesc = "Daily"; break;		case '2': PeriodDesc = "Weekly"; break;		case '3': PeriodDesc = "Monthly"; break;		case '4': PeriodDesc = "Yearly"; break;		default: PeriodDesc = ""; break;		}		fprintf(file, "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.01 Transitional//EN\">\n");	fprintf(file, "<HTML>\n<HEAD>\n<TITLE>Bandwidthd</TITLE>\n");	if (config.meta_refresh)		fprintf(file, "<META HTTP-EQUIV=\"REFRESH\" content=\"%u\">\n",				config.meta_refresh);	fprintf(file, "<META HTTP-EQUIV=\"EXPIRES\" content=\"-1\">\n");	fprintf(file, "<META HTTP-EQUIV=\"PRAGMA\" content=\"no-cache\">\n");	fprintf(file, "</HEAD>\n<BODY vlink=blue>\n%s<br>\n<center><img src=\"logo.gif\" ALT=\"Logo\"><BR>\n", ctime(&WriteTime));	fprintf(file, "Programmed by David Hinkle, Commissioned by <a href=\"http://www.derbytech.com\">DerbyTech</a> wireless networking.<BR>");	fprintf(file, "<BR>\n - <a href=\"index.html\">Daily</a> -- <a href=\"index2.html\">Weekly</a> -- ");	fprintf(file, "<a href=\"index3.html\">Monthly</a> -- <a href=\"index4.html\">Yearly</a> - <BR>\n");	fprintf(file, "<BR>\nPick a Subnet:<BR>\n");		if (config.tag == '1')		fprintf(file, "- <a href=\"index.html\">Top20</a> -");	else		fprintf(file, "- <a href=\"index%c.html\">Top20</a> -", config.tag);	for (Counter = 0; Counter < SubnetCount; Counter++)            		{		HostIp2CharIp(SubnetTable[Counter].ip, Buffer1);		fprintf(file, "- <a href=\"Subnet-%c-%s.html\">%s</a> -", config.tag, Buffer1, Buffer1);		}	/////  TOP 20	fprintf(file, "<H1>Top 20 IPs by Traffic - %s</H1></center>", PeriodDesc);	fprintf(file, "<center>\n<table width=\"100%%\" border=1 cellspacing=0>\n");    // PASS 1:  Write out the table	fprintf(file, "<TR bgcolor=lightblue><TD>Ip and Name<TD align=center>Total<TD align=center>Total Sent<TD align=center>Total Received<TD align=center>FTP<TD align=center>HTTP<TD align=center>P2P<TD align=center>TCP<TD align=center>UDP<TD align=center>ICMP\n");	for (Counter=0; Counter < 21 && Counter < NumIps; Counter++)		PrintTableLine(file, SummaryData[Counter], Counter);	fprintf(file, "</table></center>\n");	// PASS 2: The graphs	for (Counter=0; Counter < 21 && Counter < NumIps; Counter++)		if (SummaryData[Counter]->Graph)			{			if (SummaryData[Counter]->IP == 0)				{				strcpy(Buffer1, "Total");					strcpy(HostName, "Total of all subnets");				}			else				{					HostIp2CharIp(SummaryData[Counter]->IP, Buffer1);				rdns(HostName, SummaryData[Counter]->IP);				}			fprintf(file, "<a name=\"%s-%c\"></a><H1><a href=\"#top\">(Top)</a> %s - %s</H1><BR>\nSend:<br>\n<img src=%s-%c-S.png ALT=\"Sent traffic for %s\"><BR>\n<img src=legend.gif ALT=\"Legend\"><br>\nReceived:<br>\n<img src=%s-%c-R.png ALT=\"Sent traffic for %s\"><BR>\n<img src=legend.gif ALT=\"Legend\"><br>\n<BR>\n", Buffer1, config.tag, Buffer1, HostName, Buffer1, config.tag, Buffer1, Buffer1, config.tag, Buffer1);			}	fprintf(file, "</BODY></HTML>\n");	fclose(file);	////////////////////////////////////////////////	// Print each subnet page	for (SubnetCounter = 0; SubnetCounter < SubnetCount; SubnetCounter++)		{		HostIp2CharIp(SubnetTable[SubnetCounter].ip, Buffer1);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本91福利区| 亚洲免费视频成人| 亚洲精品亚洲人成人网| 欧美电视剧免费全集观看| 精品视频在线免费观看| 91捆绑美女网站| 日本久久一区二区三区| 91视频在线观看免费| 欧美日韩一区二区欧美激情| 欧美中文字幕一二三区视频| 久久精品国产99久久6| 国产在线精品一区二区夜色 | 成人一二三区视频| 中文字幕在线一区二区三区| 99麻豆久久久国产精品免费优播| 一区二区国产盗摄色噜噜| 在线综合+亚洲+欧美中文字幕| 蜜臀av一级做a爰片久久| 26uuu精品一区二区| 青青草国产成人99久久| 国产精品国产三级国产三级人妇| 一区二区三区精品在线观看| 欧美性做爰猛烈叫床潮| 无码av免费一区二区三区试看| 日韩一二三四区| 国产ts人妖一区二区| 亚洲欧洲精品一区二区三区不卡| 日本韩国欧美三级| 精品国产免费人成在线观看| 久久精品夜色噜噜亚洲a∨| 日本亚洲最大的色成网站www| 青青青伊人色综合久久| 成人av一区二区三区| 91精品国产入口| 国产精品国产三级国产有无不卡 | 欧美日韩国产a| 日韩黄色在线观看| 久久久蜜臀国产一区二区| 色综合久久久久久久久| 精品中文字幕一区二区| 亚洲精品写真福利| 久久久久久久久久看片| 欧美性受xxxx黑人xyx性爽| 黄色精品一二区| 亚洲高清三级视频| 中文一区二区在线观看| 日韩一级免费一区| 欧美亚洲一区二区三区四区| 国产精品一区二区在线看| 日韩1区2区3区| 亚洲一区二区三区四区在线| 久久精品无码一区二区三区| 91精品在线观看入口| 91小视频免费观看| 99久久久久久| 国产老妇另类xxxxx| 美女一区二区在线观看| 亚洲综合色区另类av| 国产精品少妇自拍| 欧美mv和日韩mv国产网站| 欧美精品三级日韩久久| 在线观看一区日韩| 99re8在线精品视频免费播放| 国产麻豆日韩欧美久久| 精久久久久久久久久久| 日韩在线a电影| 亚洲.国产.中文慕字在线| 亚洲四区在线观看| 欧美激情在线观看视频免费| 精品国产露脸精彩对白| 在线不卡的av| 欧美巨大另类极品videosbest| 91视频一区二区| 99久久婷婷国产综合精品| 波波电影院一区二区三区| 久色婷婷小香蕉久久| 亚洲成人黄色小说| 五月激情综合婷婷| 日韩精品乱码免费| 亚洲视频电影在线| 亚洲永久免费视频| 亚洲国产wwwccc36天堂| 亚洲高清免费视频| 亚洲丶国产丶欧美一区二区三区| 午夜日韩在线电影| 日本强好片久久久久久aaa| 日本欧美肥老太交大片| 激情欧美一区二区| 国产精品亚洲第一| 白白色亚洲国产精品| 91麻豆免费视频| 欧美亚洲一区二区在线| 欧美男女性生活在线直播观看| 欧美日韩色一区| 日韩一区二区三区在线视频| 精品日韩欧美一区二区| 国产视频一区二区在线观看| 中文字幕av在线一区二区三区| 中文字幕av不卡| 亚洲国产精品一区二区www在线| 视频在线观看91| 国产老妇另类xxxxx| 91免费国产视频网站| 欧美午夜免费电影| 欧美日本一区二区| 久久日韩粉嫩一区二区三区 | 91精品国产91久久综合桃花| 精品国产一区二区三区不卡 | 久久99国内精品| 国产99久久久久| 欧洲精品视频在线观看| 91精品国产aⅴ一区二区| 国产视频不卡一区| 亚洲天堂网中文字| 蜜桃av一区二区三区电影| 国产xxx精品视频大全| 色欧美88888久久久久久影院| 欧美日韩精品一区二区在线播放 | 国产精品视频线看| 亚洲综合丁香婷婷六月香| 蜜臀精品一区二区三区在线观看 | 久久蜜桃av一区精品变态类天堂| 中文字幕一区二区三区四区 | 中文字幕在线观看不卡| 日本不卡一二三| av中文一区二区三区| 欧美日韩大陆一区二区| 国产午夜精品一区二区三区四区| 亚洲成在人线免费| 成人美女视频在线看| 欧美va亚洲va香蕉在线| 夜夜亚洲天天久久| 国产毛片精品视频| 欧美日韩的一区二区| 最新国产精品久久精品| 美女高潮久久久| 欧美日韩国产精选| 久久伊人蜜桃av一区二区| 婷婷综合久久一区二区三区| 97久久超碰国产精品| 国产丝袜欧美中文另类| 日韩电影一区二区三区四区| 91热门视频在线观看| 久久免费视频色| 欧美96一区二区免费视频| 91日韩一区二区三区| 国产午夜一区二区三区| 亚洲一区二区视频在线观看| 国产a视频精品免费观看| 欧美一区二区美女| 香蕉久久一区二区不卡无毒影院 | 国产91高潮流白浆在线麻豆 | 国产成人a级片| 欧美zozozo| 日av在线不卡| 欧美吞精做爰啪啪高潮| 亚洲黄色av一区| 色综合久久精品| 1024国产精品| 99精品视频在线免费观看| 国产亚洲精品中文字幕| 日本vs亚洲vs韩国一区三区二区| 欧美私人免费视频| 亚洲另类春色国产| 99国产精品久久久久| 亚洲视频一区二区在线| 成人白浆超碰人人人人| 欧美激情综合五月色丁香 | 成人18视频日本| 国产精品久久久爽爽爽麻豆色哟哟| 成熟亚洲日本毛茸茸凸凹| 国产三级精品三级在线专区| 成人18精品视频| 综合欧美亚洲日本| 在线观看一区日韩| 婷婷久久综合九色综合绿巨人| 欧美日韩一区成人| 午夜精品福利一区二区蜜股av | 亚洲男人的天堂av| 91国模大尺度私拍在线视频| 一区二区三区精品在线观看| 欧美日韩激情在线| 蜜臀av在线播放一区二区三区 | 国产精品嫩草99a| a级精品国产片在线观看| 亚洲日本在线天堂| 欧美三级欧美一级| 看片的网站亚洲| 欧美国产日韩a欧美在线观看| 99精品国产99久久久久久白柏| 亚洲精品五月天| 欧美精品久久天天躁| 国内精品视频666| 国产精品不卡视频| 精品1区2区3区| 国产在线精品一区二区夜色| 中文字幕日韩av资源站| 欧美丝袜丝nylons| 日韩av一二三| 欧美国产亚洲另类动漫|