免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 13554 | 回复: 10
打印 上一主题 下一主题

那里能找到netstat的源代码阿? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-07-06 20:16 |只看该作者 |倒序浏览
linux下的?
想要得到特定的tcp连接信息,分析/proc/net/tcp可以实现但是感觉自己写的效率不太高。
那位大虾指点一下。

论坛徽章:
0
2 [报告]
发表于 2006-07-06 21:24 |只看该作者

  1. /*
  2. #-------------------------------------------------------------------------------
  3. #                                                                                                                        
  4. # $Id: netstat-nat.c,v 1.28 2005/01/29 15:24:37 mardan Exp $     
  5. #      
  6. # $Log: netstat-nat.c,v $
  7. # Revision 1.28  2005/01/29 15:24:37  mardan
  8. # Some cleanups, bumped to version 1.4.5
  9. #
  10. # Revision 1.27  2005/01/23 16:33:09  mardan
  11. # Added protocol resolving
  12. #
  13. # Revision 1.26  2005/01/21 22:54:14  mardan
  14. # Added some forgotten states
  15. #
  16. # Revision 1.25  2005/01/01 17:02:24  mardan
  17. # Extraction of IPs and ports more dynamicly so it can be used with layer7 and
  18. # maybe others when layout of ip_conntrack changes
  19. # Added autoconf
  20. #
  21. # Revision 1.24  2003/09/01 20:36:52  mardan
  22. # Fixed small bug which didn't allow to display hostnames in expanded mode,
  23. # not enough bytes where allocated.
  24. #
  25. # Revision 1.23  2003/08/31 10:59:15  mardan
  26. # Merged patch from Guomundur D. Haraldsson <gdh@binhex.EU.org> which does a
  27. # more properly memory alloction and saver copies of variables.
  28. # Changed versions to v1.4.3. Ready to release if found stable.
  29. # Changed my e-mail to danny@tweegy.demon.nl
  30. #
  31. # Revision 1.22  2003/02/08 17:41:44  mardan
  32. # made some last minor changes.
  33. # ready to release v1.4.2
  34. #
  35. # Revision 1.21  2003/01/24 21:24:34  mardan
  36. # Added unknown protocol, display as 'raw'
  37. # Fixed hussle up in states when sorting connections
  38. #
  39. # Revision 1.20  2003/01/02 15:40:48  mardan
  40. # Merged patch from Marceln, which removes unused variables, more understandable
  41. # memory allocation error message, check to exit when there are no NAT connections
  42. # and making netstat-nat compatible with uLibC.
  43. # Updated files to v1.4.2
  44. #
  45. # Revision 1.19  2002/09/22 20:10:19  mardan
  46. # Added '-v: print version'
  47. # Added 'uninstall' to Makefile
  48. # Updated all other files.
  49. #
  50. # Revision 1.18  2002/09/22 17:16:08  mardan
  51. # Rewritten connection_table to allocate memory dynamicly.
  52. #
  53. # Revision 1.17  2002/09/12 19:32:12  mardan
  54. # Added display local connections to NAT box self
  55. # Updated README
  56. # Small changes in Makefile
  57. #
  58. # Revision 1.16  2002/09/08 20:23:48  mardan
  59. # Added sort by connection option. (source/destination IP/port)
  60. # Updated README and man-page.
  61. #
  62. # Revision 1.15  2002/08/07 19:25:59  mardan
  63. # Fixed bug, displayed wrong icmp connection in state REPLIED (dest was gateway).
  64. #
  65. # Revision 1.14  2002/08/07 19:02:54  mardan
  66. # Fixed 'icmp' bug. Segmentation fault occured when displaying NATed icmp connections.
  67. #
  68. # Revision 1.13  2002/08/06 19:32:54  mardan
  69. # Added small feature: no header output.
  70. # Lots of code cleanup.
  71. #
  72. # Revision 1.12  2002/08/03 00:22:22  mardan
  73. # Added portname resolving based on the listed names in 'services'.
  74. # Re-arranged the layout.
  75. # Added a Makefile and a header file.
  76. # Updated the README.
  77. #
  78. # Revision 1.11  2002/07/12 20:05:54  mardan
  79. # Added argument for extended view of hostnames.
  80. # Moved display-code into one function.
  81. # Removed most unnessacery code.
  82. # Updated README
  83. #
  84. # Revision 1.10  2002/07/10 19:58:33  mardan
  85. # Added filtering by destination-host, re-arranged some code to work properly.
  86. # Tested DNAT icmp and udp.(pls report if any bugs occur)
  87. # Fixed a few declaration bugs.
  88. #
  89. # Revision 1.9  2002/07/09 20:00:36  mardan
  90. # Added fully DNAT support (udp & icmp not fully tested yet, but should work),
  91. # including argument support for (S)(D)NAT selection.
  92. # Re-arranged layout code, can possible merged into one function.
  93. # Some few minor changes.
  94. # Started to work on destination-host selection.
  95. #
  96. # Revision 1.8  2002/07/07 20:27:47  mardan
  97. # Added display by source host/IP.
  98. # Made a few fixes/changes.
  99. # Updated the REAMDE.
  100. #
  101. # Revision 1.7  2002/06/30 19:55:41  mardan
  102. # Added README and COPYING (license) FILES.
  103. #
  104. # Revision 1.6  2002/06/23 16:27:26  mardan
  105. # Finished udp.
  106. # Maybe some layout changes in future? therwise tool is finished.
  107. #
  108. # Revision 1.5  2002/06/23 14:07:46  mardan
  109. # Added protocol arg option.
  110. # Todo: udp protocol
  111. #
  112. # Revision 1.4  2002/06/23 12:57:35  mardan
  113. # Added ident strings for test :-)
  114. #
  115. # Revision 1.3  2002/06/23 12:47:08  mardan
  116. # Fixed resolved hostname hussle-up/layout
  117. # Moved all source code into netstat-nat.c
  118. #
  119. # Revision 1.2  2002/06/23 11:56:09  mardan
  120. # Added NAT icmp display.
  121. # Still need to do udp (more states possible)
  122. # Really need to fix resolved hostnames display, still hussled up.
  123. #
  124. # Revision 1.1.1.1  2002/05/04 01:08:06  mardan
  125. # Initial import of netstat-nat, the C version.
  126. # Array pointers really needs to be fixed, still lots of other bugs..
  127. # So far only TCP displayed.
  128. # No commandline args for e.g. no_nameresolving, protocol.
  129. #
  130. #
  131. #                                                                                                                  
  132. # Copyright (c) 2005 by D.Wijsman (danny@tweegy.demon.nl).
  133. # All rights reserved.
  134. #
  135. # This program is free software; you can redistribute it and/or modify it
  136. # under the terms of the GNU General Public License as published by the Free
  137. # Software Foundation; either version 2 of the License, or (at your option)
  138. # any later version.
  139. #
  140. # This program is distributed in the hope that it will be useful, but WITHOUT
  141. # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  142. # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  143. # more details.
  144. #
  145. # You should have received a copy of the GNU General Public License
  146. # along with this program; see the file COPYING.  If not, write to
  147. # the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  148. #               
  149. #                                                                                                                        
  150. #-------------------------------------------------------------------------------
  151. */

  152. #include "netstat-nat.h"

  153. static char const rcsid[] = "$Id: netstat-nat.c,v 1.28 2005/01/29 15:24:37 mardan Exp $";
  154. char SRC_IP[50];
  155. char DST_IP[50];
  156. int SNAT = 1;
  157. int DNAT = 1;
  158. int LOCAL = 0;
  159. static char PROTOCOL[4];
  160. int connection_index = 0;
  161. char ***connection_table;



  162. int main(int argc, char *argv[])
  163.     {
  164.     const char *args = "hnp:s:d:SDxor:L?v";
  165.     static int SORT_ROW = 1;
  166.     static int EXT_VIEW = 0;
  167.     static int RESOLVE = 1;
  168.     static int no_hdr = 0;
  169.     FILE *f;
  170.     char line[200];
  171.     char src[50];
  172.     char dst[50];
  173.     char buf[100];
  174.     char buf2[100];
  175.     char from[50] = "NATed Address";
  176.     char dest[50] = "Foreign Address";
  177.    
  178.     char ***pa;
  179.     char *store;
  180.     int index, a, b, c, j, r;
  181.    
  182.     connection_table = (char ***) xcalloc((1) * sizeof(char **));

  183.     // check parameters
  184.     while ((c = getopt(argc, argv, args)) != -1) {
  185.         switch (c) {
  186.         case 'h':
  187.             display_help();
  188.             return 1;
  189.         case '?':
  190.             display_help();
  191.             return 1;
  192.         case 'v':
  193.             printf("Version %s\n", VERSION);
  194.             return(0);
  195.         case 'n':
  196.             RESOLVE = 0;
  197.             break;
  198.         case 'p':
  199.             strcopy(PROTOCOL, sizeof(PROTOCOL), optarg);
  200.             break;
  201.         case 's':
  202.             strcopy(SRC_IP, sizeof(SRC_IP), optarg);
  203.             lookup_ip(SRC_IP, sizeof(SRC_IP));
  204.             break;
  205.         case 'd':
  206.             strcopy(DST_IP, sizeof(DST_IP), optarg);
  207.             lookup_ip(DST_IP, sizeof(DST_IP));
  208.             break;   
  209.         case 'S':
  210.             DNAT = 0;
  211.             break;
  212.         case 'D':
  213.             SNAT = 0;
  214.             break;
  215.         case 'L':
  216.             SNAT = 0;
  217.             DNAT = 0;
  218.             LOCAL = 1;
  219.             break;
  220.         case 'x':
  221.             EXT_VIEW = 1;
  222.             break;
  223.         case 'o':
  224.             no_hdr = 1;
  225.             break;
  226.         case 'r':
  227.             if (optarg == NULL || optarg == '\0') {
  228.                 display_help();
  229.                 return 1;
  230.                 }
  231.             if (strcmp(optarg, "scr") == 0) SORT_ROW = 1; //default
  232.             if (strcmp(optarg, "dst") == 0) SORT_ROW = 2;
  233.             if (strcmp(optarg, "src-port") == 0) SORT_ROW = 3;
  234.             if (strcmp(optarg, "dst-port") == 0) SORT_ROW = 4;
  235.             if (strcmp(optarg, "state") == 0) SORT_ROW = 5;
  236.             break;
  237.         }
  238.     }
  239.    
  240.     // some checking for IPTables and read file
  241.     if ((f = fopen("/proc/net/ip_conntrack","r")) == NULL) {
  242. //    if ((f = fopen("./conntrack.dump","r")) == NULL) {
  243.         printf("Could not read info about connections from the kernel, make sure netfilter is enabled in kernel or by modules.\n");
  244.         return 1;
  245.         }
  246.    
  247.     // process conntrack table
  248.     if (!no_hdr) {
  249.         if (LOCAL) {
  250.             strcopy(from, sizeof(from), "Source Address");
  251.             strcopy(dest, sizeof(dest), "Destination Address");
  252.             }
  253.         if (!EXT_VIEW) {
  254.             printf("%-6s%-31s%-31s%-6s\n", "Proto", from, dest, "State");
  255.         } else {
  256.             printf("%-6s%-41s%-41s%-6s\n", "Proto", from, dest, "State");
  257.             }
  258.         }

  259.     while (fgets(line, sizeof(line), f) != NULL)
  260.     {
  261.         process_entry(line);
  262.     }

  263.     fclose(f);
  264.    
  265.     // create index of arrays pointed to main connection array
  266.     if (connection_index == 0) {
  267.         // There are no connections at this moment!
  268.         return (0);
  269.         }
  270.    
  271.     pa = (char ***) xcalloc((connection_index) * sizeof(char **));

  272.     for (index = 0; index < connection_index; index++) {
  273.         pa[index] = (char **) xcalloc((ROWS) * sizeof(char *));

  274.         for (j = 0; j < ROWS; j++) {
  275.             pa[index][j] = (char *) xcalloc(2);
  276.             pa[index][j] = &connection_table[index][j][0];
  277.             }
  278.         }
  279.     // sort by protocol and defined row
  280.     for (a = 0; a < connection_index - 1; a++) {
  281.         for (b = a + 1; b < connection_index; b++) {
  282.             r = strcmp(pa[a][0], pa[b][0]);
  283.             if (r > 0) {
  284.                 for (j = 0; j < ROWS; j++) {
  285.                     store = pa[a][j];
  286.                     pa[a][j] = pa[b][j];
  287.                     pa[b][j] = store;
  288.                     }
  289.                 }
  290.             if (r == 0) {
  291.                 if (strcmp(pa[a][SORT_ROW], pa[b][SORT_ROW]) > 0) {
  292.                     for (j = 0; j < ROWS; j++) {
  293.                         store = pa[a][j];
  294.                         pa[a][j] = pa[b][j];
  295.                         pa[b][j] = store;
  296.                         }
  297.                     }
  298.                 }
  299.             }
  300.         }
  301.     // print connections
  302.     for (index = 0; index < connection_index; index++) {  
  303.         if (RESOLVE) {
  304.             lookup_hostname(&pa[index][1]);
  305.             lookup_hostname(&pa[index][2]);
  306.             if (strlen(pa[index][3]) > 0 || strlen(pa[index][4]) > 0) {
  307.                 lookup_portname(&pa[index][3], pa[index][0]);
  308.                 lookup_portname(&pa[index][4], pa[index][0]);
  309.                     }
  310.             }
  311.         if (!EXT_VIEW) {
  312.             strcopy(buf, sizeof(buf), "");
  313.             strncat(buf, pa[index][1], 29 - strlen(pa[index][3]));   
  314.             if (!strcmp(pa[index][0], "tcp") || !strcmp(pa[index][0], "udp")) {
  315.                 snprintf(buf2, sizeof(buf2), "%s:%s", buf, pa[index][3]);            
  316.             }
  317.             else {
  318.                 snprintf(buf2, sizeof(buf2), "%s", buf);
  319.             }
  320.             snprintf(src, sizeof(src),  "%-31s", buf2);
  321.             strcopy(buf, sizeof(buf), "");
  322.             strncat(buf, pa[index][2], 29 - strlen(pa[index][4]));   
  323.             if (!strcmp(pa[index][0], "tcp") || !strcmp(pa[index][0], "udp")) {
  324.                 snprintf(buf2, sizeof(buf2), "%s:%s", buf, pa[index][4]);            
  325.             }
  326.             else {
  327.                 snprintf(buf2, sizeof(buf2), "%s", buf);
  328.             }
  329.             snprintf(dst, sizeof(dst), "%-31s", buf2);
  330.         } else {
  331.             strcopy(buf, sizeof(buf), "");
  332.             strncat(buf, pa[index][1], 39 - strlen(pa[index][3]));   
  333.             if (!strcmp(pa[index][0], "tcp") || !strcmp(pa[index][0], "udp")) {
  334.                 snprintf(buf2, sizeof(buf2), "%s:%s", buf, pa[index][3]);
  335.             }
  336.             else {
  337.                 snprintf(buf2, sizeof(buf2), "%s", buf);
  338.             }
  339.             snprintf(src , sizeof(src), "%-41s", buf2);
  340.             strcopy(buf, sizeof(buf), "");
  341.             strncat(buf, pa[index][2], 39 - strlen(pa[index][4]));   
  342.             if (!strcmp(pa[index][0], "tcp") || !strcmp(pa[index][0], "udp")) {
  343.                 snprintf(buf2, sizeof(buf2), "%s:%s", buf, pa[index][4]);
  344.             }
  345.             else {
  346.                 snprintf(buf2, sizeof(buf2), "%s", buf);
  347.             }
  348.             snprintf(dst, sizeof(dst), "%-41s", buf2);
  349.             }
  350.         printf("%-6s%s%s%-11s\n", pa[index][0], src, dst, pa[index][5]);
  351.         }
  352.     return(0);
  353.     }

  354. // get protocol
  355. int get_protocol(char *line, char *protocol)
  356. {
  357.     int i,j, protocol_nr;
  358.     char protocol_name[10] = "";
  359.     char protocol_raw[5] = "";
  360.    
  361.     if (string_search(line, "tcp")) {
  362.         memcpy(protocol, "tcp", 3);
  363.     }
  364.     else if (string_search(line, "udp")) {
  365.         memcpy(protocol, "udp", 3);
  366.     }
  367.     else if (string_search(line, "icmp")) {
  368.         memcpy(protocol, "icmp", 4);
  369.     }
  370.     else {
  371.         // here we search for protocol number and give it a name (get_protocol_name)
  372.         for (i = 0; i < strlen(line); i++ ) {
  373.             if(!strncmp(&line[i], "unknown  ", 9)) {
  374.                 i += 9;
  375.                 for (j = i; j < strlen(line); j++) {
  376.                     if (line[j] == ' ') {
  377.                         break;
  378.                     }
  379.                     strncat(protocol_raw, &line[j], 1);
  380.                 }
  381.                 protocol_nr = atoi(protocol_raw);
  382.                 get_protocol_name(protocol_name, protocol_nr);
  383.                 memcpy(protocol, protocol_name, 9);
  384.                 break;
  385.             }
  386.         }
  387.         //memcpy(protocol, "raw", 3);
  388.     }
  389. //    printf("PROTO: %s\n", protocol);
  390.     return(0);
  391. }

  392. // get connection status
  393. int get_connection_state(char *line, char *state)
  394. {
  395.     if (string_search(line, "ESTABLISHED")) {
  396.         memcpy(state, "ESTABLISHED", 11);
  397.     }
  398.     else if (string_search(line, "TIME_WAIT")) {
  399.         memcpy(state, "TIME_WAIT", 9);
  400.     }   
  401.     else if (string_search(line, "FIN_WAIT")) {
  402.         memcpy(state, "FIN_WAIT", 8);
  403.     }   
  404.     else if (string_search(line, "SYN_RECV")) {
  405.         memcpy(state, "SYN_RECV", 8);
  406.     }   
  407.     else if (string_search(line, "SYN_SENT")) {
  408.         memcpy(state, "SYN_SENT", 8);
  409.     }   
  410.     else if (string_search(line, "UNREPLIED")) {
  411.         memcpy(state, "UNREPLIED", 9);
  412.     }   
  413.     else if (string_search(line, "CLOSE")) {
  414.         memcpy(state, "CLOSE", 5);
  415.     }   
  416.     else if (string_search(line, "ASSURED")) {
  417.         memcpy(state, "ASSURED", 7);
  418.     }
  419.     else {
  420.         if (string_search(line, "udp")) {
  421.             memcpy(state, "UNREPLIED", 9);
  422.         }
  423.         else {
  424.             memcpy(state, " ", 1);
  425.         }
  426.     }   
  427. //    printf("STATE: %s\n", state);
  428.     return(0);
  429. }

  430. void process_entry(char *line)
  431. {
  432.     int count;
  433.     count = 0;
  434.     char srcip_f[16] = "";
  435.     char dstip_f[16] = "";
  436.     char srcip_s[16] = "";
  437.     char dstip_s[16] = "";
  438.     char srcport[6] = "";
  439.     char dstport[6] = "";
  440.     char protocol[5] = "";
  441.     char state[12] = "";

  442.     search_first_hit("src=", line, srcip_f);   
  443.     search_first_hit("dst=", line, dstip_f);   
  444.     search_sec_hit("src=", line, srcip_s);   
  445.     search_sec_hit("dst=", line, dstip_s);   
  446.     search_first_hit("sport=", line, srcport);   
  447.     search_first_hit("dport=", line, dstport);   

  448.     get_protocol(line, protocol);
  449.     if (strcmp(PROTOCOL, "")) {
  450.         if (strncmp(PROTOCOL, protocol, 3)) {
  451. //            printf("RETURN\n");
  452.             return;
  453.         }
  454.     }
  455.     get_connection_state(line, state);
  456.     if (SNAT) {
  457.         if ((!strcmp(srcip_f, dstip_s) == 0) && (strcmp(dstip_f, srcip_s) == 0)) {               
  458.               check_src_dst(protocol, srcip_f, dstip_f, srcport, dstport, state);
  459.             }
  460.     }
  461.     if (DNAT) {
  462.         if ((strcmp(srcip_f, dstip_s) == 0) && (!strcmp(dstip_f, srcip_s) == 0)) {               
  463.             check_src_dst(protocol, srcip_f, srcip_s, srcport, dstport, state);
  464.         }
  465.     }
  466.     if (LOCAL) {
  467.         if ((strcmp(srcip_f, dstip_s) == 0) && (strcmp(dstip_f, srcip_s) == 0)) {               
  468.             check_src_dst(protocol, srcip_f, srcip_s, srcport, dstport, state);
  469.         }
  470.     }
  471. //    printf("%s %s %s %s %s %s\n", protocol, srcip_f, dstip_f, srcip_s, dstip_s, state);
  472. }


复制代码

论坛徽章:
0
3 [报告]
发表于 2006-07-06 21:25 |只看该作者

  1. // -- Internal used functions
  2. // Check filtering by source and destination IP
  3. void check_src_dst(char *protocol, char *src_ip, char *dst_ip, char *src_port, char *dst_port, char *status)
  4.     {
  5.     if ((check_if_source(src_ip)) && (strcmp(DST_IP, "") == 0)) {
  6.         store_data(protocol, src_ip, dst_ip, src_port, dst_port, status);
  7.         }
  8.     else if ((check_if_destination(dst_ip)) && (strcmp(SRC_IP, "") == 0)) {
  9.         store_data(protocol, src_ip, dst_ip, src_port, dst_port, status);
  10.         }
  11.     else if ((check_if_destination(dst_ip)) && (check_if_source(src_ip))) {
  12.         store_data(protocol, src_ip, dst_ip, src_port, dst_port, status);
  13.         }
  14.     }

  15. void store_data(char *protocol, char *src_ip, char *dst_ip, char *src_port, char *dst_port, char *status)  
  16.     {
  17.    
  18.     connection_table = (char ***) xrealloc(connection_table, (connection_index +1) * sizeof(char **));
  19.     connection_table[connection_index] = (char **) xcalloc(200 * sizeof(char *));
  20.     connection_table[connection_index][0] = (char *) xcalloc(10);
  21.     connection_table[connection_index][1] = (char *) xcalloc(60);
  22.     connection_table[connection_index][2] = (char *) xcalloc(60);
  23.     connection_table[connection_index][3] = (char *) xcalloc(20);
  24.     connection_table[connection_index][4] = (char *) xcalloc(20);
  25.     connection_table[connection_index][5] = (char *) xcalloc(15);
  26.    
  27.     strcopy(connection_table[connection_index][3], 20, src_port);
  28.     strcopy(connection_table[connection_index][4], 20, dst_port);
  29.     strcopy(connection_table[connection_index][1], 60, src_ip);
  30.     strcopy(connection_table[connection_index][2], 60, dst_ip);
  31.     strcopy(connection_table[connection_index][0], 10, protocol);
  32.     strcopy(connection_table[connection_index][5], 15, status);
  33.     connection_index++;
  34.     }

  35. void lookup_portname(char **port, char *proto)
  36.     {
  37.     char buf_port[10];
  38.     int portnr;
  39.     struct servent *service;
  40.     size_t port_size;
  41.    
  42.     strcopy(buf_port, sizeof(buf_port), *port);
  43.     portnr = htons(atoi(buf_port));
  44.    
  45.     if ((service = getservbyport(portnr, proto))) {
  46.         port_size = strlen(service->s_name) + 8;
  47.         *port = xrealloc(*port, port_size);
  48.         strcopy(*port, port_size, service->s_name);
  49.         }
  50.     }

  51. void extract_ip(char *gen_buffer)
  52.     {
  53.     char *split;
  54.     split = strtok(gen_buffer, "=");
  55.     split = strtok(NULL, "=");
  56.     strcpy(gen_buffer, split);
  57.     }

  58. int lookup_hostname(char **r_host)
  59.     {
  60.     int addr;
  61.     struct hostent *hp;
  62.     char **p;
  63.     size_t r_host_size;

  64.     addr = inet_addr(*r_host);
  65.     if ((hp = gethostbyaddr((char *) &addr, sizeof(addr), AF_INET)) == NULL)
  66.         return 0;

  67.     for (p = hp->h_addr_list; *p != 0; p++){
  68.         struct in_addr in;
  69.         (void)memcpy(&in.s_addr, *p, sizeof(in.s_addr));
  70.         r_host_size = strlen(*r_host) + 25;
  71.         *r_host = xrealloc(*r_host, r_host_size);       
  72.         strcopy(*r_host, r_host_size, hp->h_name);
  73.         }
  74.     return 0;
  75.     }


  76. int lookup_ip(char *hostname, size_t hostname_size)
  77.     {
  78.     char *ip;
  79.     struct hostent *hp;
  80.     struct in_addr ip_addr;
  81.    
  82.     if ((hp = gethostbyname(hostname)) == NULL) {
  83.         printf("Unknown host: %s\n", hostname);
  84.         exit(-1);
  85.         }

  86.     ip_addr = *(struct in_addr *)(hp->h_addr);
  87.     ip = inet_ntoa(*(struct in_addr *)(hp->h_addr));
  88.     strcopy(hostname, hostname_size, ip);
  89.     return 1;
  90.     }
  91. /*
  92. int match(char *string, char *pattern)
  93.     {
  94.     int i;
  95.     regex_t re;
  96.     char buf[200];
  97.    
  98.     i = regcomp(&re, pattern, REG_EXTENDED|REG_NOSUB);

  99.     if (i != 0) {
  100.         (void)regerror(i, &re, buf, sizeof(buf));
  101.         return 0;                       
  102.         }
  103.    
  104.     i = regexec(&re, string, (size_t) 0, NULL, 0);
  105.     regfree(&re);

  106.     if (i != 0) {
  107.         (void)regerror(i, &re, buf, sizeof(buf));
  108.         return 0;                       
  109.         }

  110.     return 1;
  111.     }
  112. */
  113. int check_if_source(char *host)
  114.     {
  115.     if ((strcmp(host, SRC_IP) == 0) || (strcmp(SRC_IP, "") == 0)) {
  116.         return 1;
  117.         }
  118.     return 0;
  119.     }

  120. int check_if_destination(char *host)
  121.     {
  122.     if ((strcmp(host, DST_IP) == 0) || (strcmp(DST_IP, "") == 0)) {
  123.         return 1;
  124.         }
  125.     return 0;
  126.     }


  127. static void *xcalloc(size_t bufsize)
  128.     {
  129.     void *buf;
  130.        
  131.     if ((buf = calloc(1, bufsize)) != NULL) {
  132.         return buf;
  133.     } else {
  134.         printf("Could not allocate memory (%i bytes); %s.\n -- Exiting.\n", bufsize, strerror(errno));
  135.         exit(1);
  136.         }
  137.     }


  138. static void *xrealloc(void *oldbuf, size_t newbufsize)
  139.     {
  140.     void *newbuf;
  141.        
  142.     if ((newbuf = realloc(oldbuf, newbufsize)) != NULL) {
  143.         return newbuf;
  144.     } else {
  145.         printf("Could not allocate memory (%i bytes); %s.\n -- Exiting.\n", newbufsize, strerror(errno));
  146.         exit(1);
  147.         }
  148.     }


  149. int string_search(char *string, char *search)
  150. {
  151.     int searchLen;
  152.     int i;
  153.     searchLen = strlen(search);
  154.     if (searchLen > strlen(string)) {
  155.         return(0); // this can't match
  156.     }
  157.     for (i = 0; i < strlen(string) - searchLen + 1; i++) {
  158.         if (!strncasecmp((char *)&string[i], search, searchLen)) {
  159.             return(1); // we got hit
  160.         }
  161.     }
  162.     return(0);
  163. }


  164. int search_first_hit(char *search, char *line, char *ret)
  165. {
  166.     unsigned int searchLen;
  167.     unsigned int i;
  168.     unsigned int j;
  169.     unsigned int lineLen;
  170.    
  171.     lineLen = strlen(line);
  172.     searchLen = strlen(search);

  173.     if (searchLen > lineLen) {
  174.         return(1); // this can't match, invalid data?
  175.     }
  176.     for (i = 0; i < lineLen - searchLen + 1; i++) {
  177.         if (!strncasecmp((char *)&line[i], search, searchLen)) {
  178.             break; // we got hit
  179.         }
  180.     }
  181.     for (j = i + searchLen; j < i + 15 + searchLen; j++) {
  182.         if (j > lineLen) {
  183.             return(1); // incomplete data
  184.         }
  185.         if (line[j] == ' ') {
  186.             break; // we reach _space_ delimiter
  187.         }
  188.     }
  189.     memcpy(ret, &line[i + searchLen], j - i - searchLen);
  190.     return(0);
  191. }


  192. int search_sec_hit(char *search, char *line, char *ret)
  193. {
  194.     unsigned int searchLen;
  195.     unsigned int i;
  196.     unsigned int j;
  197.     unsigned int got_first = 0;
  198.     unsigned int lineLen;
  199.    
  200.     lineLen = strlen(line);
  201.     searchLen = strlen(search);

  202.     if (searchLen > lineLen) {
  203.         return(1); // this can't match, invalid data?
  204.     }
  205.     for (i = 0; i < lineLen - searchLen + 1; i++) {
  206.         if (!strncasecmp((char *)&line[i], search, searchLen)) {
  207.             if (got_first) {
  208.                 break; // we got hit (second)
  209.             }
  210.             got_first = 1;
  211.         }
  212.     }
  213.     for (j = i + searchLen; j < i + 15 + searchLen; j++) {
  214.         if (j > lineLen) {
  215.             return(1); // incomplete data
  216.         }
  217.         if (line[j] == ' ') {
  218.             break; // we reach _space_ delimiter
  219.         }
  220.     }
  221.     memcpy(ret, &line[i + searchLen], j - i - searchLen);
  222.     return(0);
  223. }


  224. void get_protocol_name(char *protocol_name, int protocol_nr)
  225. {
  226.     struct protoent *proto_struct;
  227.     char strconvers[10] = "";
  228.     proto_struct = getprotobynumber(protocol_nr);
  229.     if (proto_struct != NULL) {
  230.         memcpy(protocol_name, proto_struct->p_name, 5);
  231.     }
  232.     else {
  233.         snprintf(strconvers, 6, "%d", protocol_nr);
  234.         memcpy(protocol_name, strconvers, 5);
  235.     }
  236. }


  237. void display_help()
  238.     {
  239.     printf("args: -h: displays this help\n");
  240.     printf("      -n: don't resolve host/portnames\n");
  241.     printf("      -p <protocol>        : display connections by protocol\n");
  242.     printf("      -s <source-host>     : display connections by source\n");
  243.     printf("      -d <destination-host>: display connections by destination\n");
  244.     printf("      -S: display SNAT connections\n");
  245.     printf("      -D: display DNAT connections (default: SNAT & DNAT)\n");
  246.     printf("      -L: display only connections to NAT box itself (doesn't show SNAT & DNAT)\n");
  247.     printf("      -x: extended hostnames view\n");
  248.     printf("      -r src | dst | src-port | dst-port | state : sort connections\n");
  249.     printf("      -o: strip output header\n");
  250.     printf("      -v: print version\n");
  251.     }

  252. // -- End of internal used functions

  253. // -- The End --
复制代码

论坛徽章:
0
4 [报告]
发表于 2006-07-06 21:25 |只看该作者
下面是头文件


  1. /*
  2. #-------------------------------------------------------------------------------
  3. #                                                                                                                        
  4. # $Id: netstat-nat.h,v 1.11 2005/01/29 15:24:37 mardan Exp $     
  5. #      
  6. #                                                                                                                  
  7. # Copyright (c) 2005 by D.Wijsman (danny@tweegy.demon.nl).
  8. # All rights reserved.
  9. #
  10. # This program is free software; you can redistribute it and/or modify it
  11. # under the terms of the GNU General Public License as published by the Free
  12. # Software Foundation; either version 2 of the License, or (at your option)
  13. # any later version.
  14. #
  15. # This program is distributed in the hope that it will be useful, but WITHOUT
  16. # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  17. # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  18. # more details.
  19. #
  20. # You should have received a copy of the GNU General Public License
  21. # along with this program; see the file COPYING.  If not, write to
  22. # the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  23. #               
  24. #                                                                                                                        
  25. #-------------------------------------------------------------------------------
  26. */

  27. #include <stdio.h>
  28. #include <stdlib.h>
  29. #include <string.h>
  30. //#include <regex.h>
  31. #include <netdb.h>
  32. #include <unistd.h>
  33. #include <arpa/inet.h>
  34. #include <errno.h>
  35. #include <strings.h>

  36. //#define VERSION                "1.4.4"
  37. #define ROWS                6


  38. int get_protocol(char *line, char *protocol);
  39. int get_connection_state(char *line, char *state);
  40. void process_entry(char *line);
  41. void check_src_dst(char *protocol, char *src_ip, char *dst_ip, char *src_port, char *dst_port, char *status);
  42. void store_data(char *protocol, char *src_ip, char *dst_ip, char *src_port, char *dst_port, char *status);
  43. void extract_ip(char *gen_buffer);
  44. void display_help();
  45. int lookup_hostname(char **r_host);
  46. int lookup_ip(char *hostname, size_t hostname_size);
  47. //int match(char *string, char *pattern);
  48. int check_if_source(char *host);
  49. int check_if_destination(char *host);
  50. void lookup_portname(char **port, char *proto);
  51. void oopsy(int size);
  52. static void *xrealloc(void *oldbuf, size_t newbufsize);
  53. static void *xcalloc(size_t bufsize);
  54. void get_protocol_name(char *protocol_name, int protocol_nr);

  55. #define strcopy(dst, dst_size, src) \
  56.         strncpy(dst, src, (dst_size - 1));

  57. /* The End */
复制代码

论坛徽章:
0
5 [报告]
发表于 2006-07-06 23:25 |只看该作者
感谢!!!我从freshmeat看到了这个源码,它只是显示nat的连接信息所以没看,不过到是有一定的参考价值,但是/proc/net/tcp的数据看着不大一样,有没分析这个文件的代码阿?

论坛徽章:
0
6 [报告]
发表于 2007-07-31 23:57 |只看该作者
看这个:
http://www.busybox.net/cgi-bin/v ... busybox/networking/
这个网站比较有意思,主要是为嵌入式操作系统改写linux上的一些软件,变小、变巧。这样有利于我们学习这些工具的基本原理。

论坛徽章:
0
7 [报告]
发表于 2007-08-01 09:12 |只看该作者
原帖由 newcmd 于 2006-7-6 23:25 发表
感谢!!!我从freshmeat看到了这个源码,它只是显示nat的连接信息所以没看,不过到是有一定的参考价值,但是/proc/net/tcp的数据看着不大一样,有没分析这个文件的代码阿?

Linux下的net-tools中的netstat命令就是通过分析proc文件系统实现的,我根据源码写了一个端口扫描的程序(IPV4 & IPV6),你可以参考下
http://linux.chinaunix.net/bbs/viewthread.php?tid=864757
再给你附上net-tools的源码吧,其中就有netstat route 等命令的源码

[ 本帖最后由 duanjigang 于 2007-8-1 09:15 编辑 ]

net-tools-1.40.tar.gz

120.6 KB, 下载次数: 458

论坛徽章:
0
8 [报告]
发表于 2007-08-01 09:23 |只看该作者
楼上的头像看的心里老不爽了,干嘛搞这么吓人的?

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
9 [报告]
发表于 2007-08-01 10:57 |只看该作者
原帖由 yuangong 于 2007-8-1 09:23 发表
楼上的头像看的心里老不爽了,干嘛搞这么吓人的?

直接在设置里面选择不显示头像,你就啥也看不到了

论坛徽章:
0
10 [报告]
发表于 2007-08-01 15:31 |只看该作者
原帖由 yuangong 于 2007-8-1 09:23 发表
楼上的头像看的心里老不爽了,干嘛搞这么吓人的?

女人这样的眼神多有气质啊,呵呵
要懂得欣赏
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP