⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 udp.c

📁 mgcp协议源代码。支持多种编码:g711
💻 C
字号:
/**************************************************************************** ** File: udp.c**** Author: Mike Borella**** Comments: Dump UDP header information*******************************************************************************/#include <stdio.h>#include <unistd.h>#include <arpa/inet.h>#include <netdb.h>#include <assert.h>#include "config.h"#include "udp.h"#include "rsip.h"#include "dns.h"#include "l2tp.h"#include "dhcp.h"#include "rip.h"#include "mgcp.h"#include "sip.h"#include "isakmp.h"#include "payload.h"#include "addrtoname.h"#include "error.h"extern u_char *packet_end;extern struct arg_t *my_args;/*----------------------------------------------------------------------------**** dump_udp()**** Parse UDP header and dump fields****----------------------------------------------------------------------------*/void dump_udp(u_char *bp, int length){  UDPHdr *up;  u_char *ep = bp + length;  u_short sport, dport, len;  struct servent *se;    /*   * Make sure we don't run off the end of the packet   */  if (ep > packet_end) ep = packet_end;  /*   * Check for truncated packet   */  if (length < sizeof(UDPHdr))    {      printf("Truncated header, length = %d bytes\n", length);      return;    }  up = (UDPHdr *) bp;  sport = ntohs(up->uh_src); current_ip_src_port = sport;  dport = ntohs(up->uh_dst); current_ip_dst_port = dport;  len = ntohs(up->uh_len);  /*   * Dump UDP header info   */    if (!my_args->t)    {    printf("-----------------------------------------------------------------\n");  printf("                        UDP Header\n");  printf("-----------------------------------------------------------------\n");      printf("Source port:            %d", sport);      if (sport < 1024) 	printf(" (%s)\n", udpport_string(sport));      else 	printf("\n");            printf("Destination port:       %d", dport);      if (dport < 1024) 	printf(" (%s)\n", udpport_string(dport));      else 	printf("\n");            if (!my_args->m)	{	  printf("Length:                 %d\n", len);	  printf("Checksum:               %d\n", ntohs(up->uh_chk));	}    }  /* subtract the length of the UDP Header from the len */  /* this should always be 8 bytes */  assert(sizeof(UDPHdr) == 8);  len = len - sizeof(UDPHdr);  /*   * Take care of DNS packets   */  se = getservbyname("domain", "udp");  if (se == NULL)     GWF_error_system("can't get services entries");  if (sport == ntohs(se->s_port) || dport == ntohs(se->s_port))    dump_dns((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of L2TP packets   */  if (sport == L2TP_PORT || dport == L2TP_PORT)    dump_l2tp((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of DHCP packets   */  if (sport == DHCP_CLIENT_PORT || dport == DHCP_CLIENT_PORT)    dump_dhcp((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of RIP packets   */  if (sport == RIP_PORT || dport == RIP_PORT)    dump_rip((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of SIP packets   */#if 0  if (sport == SIP_PORT || dport == SIP_PORT)    dump_sip((u_char *) bp + sizeof(UDPHdr), len);#endif  if (is_sip((u_char *) bp + sizeof(UDPHdr)))    dump_sip((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of IKE packets   */  if (sport == ISAKMP_PORT || dport == ISAKMP_PORT)    dump_isakmp((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of RSIP packets   */  if (sport == RSIP_PORT || dport == RSIP_PORT)    dump_rsip((u_char *) bp + sizeof(UDPHdr), len);  /*   * Take care of MGCP packets   */  if ( is_mgcp((u_char *) bp + sizeof(UDPHdr), len) )     dump_mgcp((u_char *) bp + sizeof(UDPHdr), len);  /*   * print payload if there is one   */  if (my_args->p && len > 0)     dump_payload((u_char *) bp + sizeof(UDPHdr), len);  return;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -