#pragma module tcpip$udp_server_sock \ "V5.1-00" /* * Copyright 2000 Compaq Computer Corporation * * COMPAQ Registered in U.S. Patent and Trademark Office. * * Confidential computer software. Valid license from Compaq * or authorized sublicensor required for possession, use or * copying. Consistent with FAR 12.211 and 12.212, Commercial * Computer Software, Computer Software Documentation, and * Technical Data for Commercial Items are licensed to the * U.S. Government under vendor's standard commercial license. * * ++ * FACILITY: * * EXAMPLES * * ABSTRACT: * * This is an example of a UDP/IP IPv4 server using 4.x BSD * socket Application Programming Interface (API) to handle * network I/O operations. * * Refer to 'Build, Configuration, and Run Instructions' for * details on how to build, configure, and run this program. * * ENVIRONMENT: * * OpenVMS Alpha/VAX V7.1 * TCP/IP Services V5.0 or higher * * AUTHOR: * * TCPIP Development Group, CREATION DATE: 23-May-1989 * * -- */ /* Build, Configuration, and Run Instructions */ /* * BUILD INSTRUCTIONS: * * To build this example program use commands of the form, * * using the DEC "C" compiler: * * $ cc/prefix=all TCPIP$UDP_SERVER_SOCK.C * $ link TCPIP$UDP_SERVER_SOCK * * using the DEC "C++" compiler: * * $ cxx/prefix=all/define=VMS TCPIP$UDP_SERVER_SOCK.C * $ link TCPIP$UDP_SERVER_SOCK * * * CONFIGURATION INSTRUCTIONS: * * No special configuration required. * * * RUN INSTRUCTIONS: * * To run this example program: * * 1) Start this server program server as shown below: * * $ run tcpip$udp_server_sock * Waiting for a client datagram on port: m * * 2) After the server program blocks, start the client program, * entering the server host as shown below: * * $ run tcpip$udp_client_sock * Enter remote host: * * Note: You can specify a server host by using either an IPv4 * address in dotted-decimal notation (e.g. 16.20.10.56) * or a host domain name (e.g. serverhost.compaq.com). * * 3) The server program then displays client address information * and client data as show below: * * Received a datagram from host: a.b.c.d, port: n * Data received: Hello, world! * * You can enter "ctrl/z" at any user prompt to terminate program * execution. * */ /* * INCLUDE FILES: */ #include /* define internet related constants, */ /* functions, and structures */ #include /* define network address info */ #include /* define network database library info */ #include /* define BSD 4.x socket api */ #include /* define standard i/o functions */ #include /* define standard library functions */ #include /* define string handling functions */ #include /* define unix i/o */ /* * NAMED CONSTANTS: */ #define SERV_PORTNUM 12345 /* server port number */ /* * FORWARD REFERENCES: */ int main( void ); /* server main */ /* Server Main */ /* * FUNCTIONAL DESCRIPTION: * * This is the server's main-line code. It handles all the tasks of the * server including: socket creation, binding a socket to the server's * internet address and port, and reading client data. * * This example program implements a typical UDP IPv4 server using the * BSD socket API to handle network i/o operations as shown below: * * 1) To create a socket: * * socket() * * 2) To set REUSEADDR socket option: * * setsockopt() * * 3) To bind internet address and port number to a socket: * * bind() * * 4) To transfer data: * * recvfrom() * * 5) To close a socket: * * close() * * This function is invoked by the DCL "RUN" command (see below); the * function's completion status is interpreted by DCL and if needed, * an error message is displayed. * * SYNOPSIS: * * int main( void ) * * FORMAL PARAMETERS: * * ** None ** * * IMPLICIT INPUTS: * * ** None ** * * IMPLICIT OUTPUTS: * * ** None ** * * FUNCTION VALUE: * * completion status * * SIDE EFFECTS: * * ** None ** * */ int main( void ) { char buf[512]; /* server data buffer */ int optval = 1; /* SO_REUSEADDR'S option value (on) */ int sockfd; /* socket descriptor */ unsigned int client_addrlen; /* returned length of client socket */ /* address structure */ struct sockaddr_in client_addr; /* client socket address structure */ struct sockaddr_in serv_addr; /* server socket address structure */ /* * init client's socket address structure */ memset( &client_addr, 0, sizeof(client_addr) ); /* * init server's socket address structure */ memset( &serv_addr, 0, sizeof(serv_addr) ); serv_addr.sin_family = AF_INET; serv_addr.sin_port = htons( SERV_PORTNUM ); serv_addr.sin_addr.s_addr = INADDR_ANY; /* * create a udp socket */ if ( (sockfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0 ) { perror( "Failed to create socket" ); exit( EXIT_FAILURE ); } /* * bind server's internet address and port number to socket */ if ( setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &optval, sizeof(optval)) < 0 ) { perror( "Failed to set socket option" ); exit( EXIT_FAILURE ); } if ( bind(sockfd, (struct sockaddr *) &serv_addr, sizeof(serv_addr)) < 0 ) { perror( "Failed to bind socket" ); exit( EXIT_FAILURE ); } /* * read datagram from client */ printf( "Waiting for a client datagram on port: %d\n", ntohs(serv_addr.sin_port) ); client_addrlen = sizeof(client_addr); if ( recvfrom(sockfd, buf, sizeof(buf), 0, (struct sockaddr *) &client_addr, &client_addrlen) < 0 ) { perror( "Failed to read datagram from client" ); exit( EXIT_FAILURE ); } printf( "Received a datagram from host: %s, port: %d\n", inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port) ); printf( "Data received: %s\n", buf ); /* output client's data buffer */ /* * close udp socket */ if ( close(sockfd) < 0 ) { perror( "Failed to close socket" ); exit( EXIT_FAILURE ); } exit( EXIT_SUCCESS ); }