亚洲欧美第一页_禁久久精品乱码_粉嫩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在线看| 久久久亚洲综合| 成人性生交大片免费看中文网站| 国产精品久久久久久妇女6080| 在线观看国产精品网站| 麻豆免费看一区二区三区| 精品欧美乱码久久久久久| 久草热8精品视频在线观看| 国产精品久久久久久久久免费丝袜 | 国产精品卡一卡二| 欧美三级欧美一级| 国产在线精品免费av| 一区二区三区.www| 欧美精品一区二区三区高清aⅴ | 久久精品久久精品| 国产人久久人人人人爽| 成人午夜免费视频| 亚洲国产精品久久久男人的天堂| 久久久影视传媒| 在线观看视频欧美| 国产福利不卡视频| 亚洲电影第三页| 国产精品日韩精品欧美在线| 欧美一区二区三区四区五区| 国产在线国偷精品产拍免费yy| 国产精品成人免费精品自在线观看| 91精品国产综合久久精品图片| av男人天堂一区| 国产综合一区二区| 日本成人在线视频网站| 自拍偷拍欧美激情| 精品粉嫩aⅴ一区二区三区四区| 色菇凉天天综合网| 国产一区二区三区在线观看免费 | 日韩视频一区二区在线观看| 成人晚上爱看视频| 久久99热这里只有精品| 亚洲成人在线网站| 国产精品美女久久久久久久| 久久久综合九色合综国产精品| 欧美另类久久久品| 欧美伊人久久久久久午夜久久久久| 国产不卡免费视频| 国产一区二区三区香蕉| 午夜欧美一区二区三区在线播放| 国产精品素人一区二区| 中文字幕乱码日本亚洲一区二区| 精品国产一二三| 91精品国产aⅴ一区二区| 在线国产电影不卡| 日韩成人av影视| 亚洲最大成人综合| 亚洲精品国产成人久久av盗摄| 国产精品网站在线| 久久久www成人免费毛片麻豆 | 99久精品国产| 青青草精品视频| 午夜亚洲福利老司机| 亚洲欧洲精品一区二区精品久久久 | 亚洲图片欧美激情| 中文字幕欧美三区| 国产精品午夜电影| 国产欧美日韩在线| 日韩视频不卡中文| 欧美va亚洲va在线观看蝴蝶网| 56国语精品自产拍在线观看| 欧美日韩一区三区| 欧美色偷偷大香| 欧美妇女性影城| 欧美成人bangbros| 久久久久国产精品人| 亚洲精品一区二区三区四区高清| 亚洲精品一区二区在线观看| 久久精品视频一区二区三区| 欧美韩日一区二区三区四区| 最新国产の精品合集bt伙计| 亚洲猫色日本管| 五月综合激情婷婷六月色窝| 日日骚欧美日韩| 久草中文综合在线| 成人午夜激情影院| 99精品国产99久久久久久白柏| 成人免费毛片a| 91社区在线播放| 在线观看区一区二| 欧美电影免费提供在线观看| 国产亚洲欧美中文| 亚洲精品乱码久久久久久黑人| 亚洲综合久久久| 日本高清不卡视频| 一本久道久久综合中文字幕| 色美美综合视频| 欧美一区二区三区免费在线看| 欧美一区二区三区免费视频 | 偷窥国产亚洲免费视频| 中文无字幕一区二区三区| 久久综合资源网| 国产精品丝袜91| 亚洲最新视频在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产电影一区二区三区| 日本高清成人免费播放| 2023国产一二三区日本精品2022| 国产精品毛片高清在线完整版| 亚洲成人av一区二区| 视频在线观看91| 国产成人精品亚洲777人妖| 欧美羞羞免费网站| 精品美女一区二区三区| 国产精品传媒视频| 麻豆免费精品视频| 色综合久久88色综合天天免费| 日韩欧美亚洲国产精品字幕久久久 | 欧美一区二区人人喊爽| 国产精品三级在线观看| 日韩1区2区日韩1区2区| 91亚洲精品乱码久久久久久蜜桃 | 一区二区三区成人| 韩国午夜理伦三级不卡影院| 91精品91久久久中77777| 精品欧美一区二区久久| 亚洲欧洲综合另类| 丰满少妇在线播放bd日韩电影| 在线不卡欧美精品一区二区三区| 久久青草国产手机看片福利盒子| 亚洲亚洲精品在线观看| 成人黄色一级视频| 精品国产乱码久久久久久牛牛| 一区二区三区免费在线观看| 国产99精品国产| 精品美女一区二区| 一区二区三区中文在线| 成人久久18免费网站麻豆| 日韩一区二区三区免费观看| 国产精品三级在线观看| 午夜精品视频一区| 91久久线看在观草草青青 | 亚洲综合激情网| 99re成人精品视频| 欧美极品aⅴ影院| 免费人成精品欧美精品| 99v久久综合狠狠综合久久| 精品国产一二三| 国产毛片精品视频| 国产亚洲一本大道中文在线| 成人午夜视频在线观看| 色婷婷久久久亚洲一区二区三区| 成人欧美一区二区三区小说 | 中文字幕精品—区二区四季| 国产69精品久久777的优势| 中文字幕欧美国产| 一本久久a久久免费精品不卡| 亚洲中国最大av网站| 欧美精品一二三| 久久国产日韩欧美精品| 亚洲国产精品黑人久久久| 91麻豆免费看片| 亚洲成av人片| 2014亚洲片线观看视频免费| 岛国一区二区在线观看| 国产精品久久久久久久久图文区| 色久优优欧美色久优优| 日韩 欧美一区二区三区| 久久久久久黄色| 色综合久久99| 久久精品国产亚洲一区二区三区 | 最好看的中文字幕久久| 欧美日韩在线播| 国产精品综合av一区二区国产馆| 中文字幕制服丝袜一区二区三区| 91国产免费观看| 狠狠色丁香久久婷婷综合丁香| 国产精品不卡一区| 欧美一三区三区四区免费在线看| 国内精品伊人久久久久影院对白| 中文字幕一区不卡| 欧美一级高清大全免费观看| 国产aⅴ精品一区二区三区色成熟| 亚洲精品va在线观看| 精品国产区一区| 在线免费av一区| 国产一区二区在线看| 一区二区三区在线观看视频| 精品国产乱码91久久久久久网站| 91在线视频官网| 黑人巨大精品欧美一区| 一区二区成人在线| 久久久91精品国产一区二区精品| 欧美三级韩国三级日本一级| 激情五月播播久久久精品| 一区二区三区欧美激情| 国产三级久久久| 91麻豆精品国产91久久久资源速度 | 日本不卡一二三| 一区二区三区高清不卡| 国产免费成人在线视频| 制服丝袜一区二区三区| 97se狠狠狠综合亚洲狠狠| 精品一区二区三区欧美|