• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            tqsheng

            go.....
            隨筆 - 366, 文章 - 18, 評論 - 101, 引用 - 0
            數據加載中……

            UDP服務器端程序設計



            二、實驗平臺

            ubuntu-8.04操作系統

            三、實驗內容

            編寫Linux下UDP服務器套接字程序,服務器接收客戶端發送的信息并顯示,同時顯示客戶的IP地址、端口號,并向客戶端發送信息。如果服務器接收的客戶信息為“bye”,則退出循環,并關閉套接字。

            四、實驗原理

            UDP套接口是無連接的、不可靠的數據報協議;既然他不可靠為什么還要用呢?其一:當應用程序使用廣播或多播時只能使用UDP協議;其二:由于他是無連接的,所以速度快。因為UDP套接口是無連接的,如果一方的數據報丟失,那另一方將無限等待,解決辦法是設置一個超時。

            建立UDP套接口時socket函數的第二個參數應該是SOCK_DGRAM,說明是建立一個UDP套接口;由于UDP是無連接的,所以服務器端并不需要listen或accept函數。

            使用UDP套接字編程可以實現基于TCP/IP協議的面向無連接的通信,它分為服務器端和客戶端兩部分,其主要實現過程如圖3.1所示。


                                                                  圖3.1 UDP客戶/服務器的套接字函數


             1、socket函數:為了執行網絡輸入輸出,一個進程必須做的第一件事就是調用socket函數獲得一個文件描述符。

            -----------------------------------------------------------------
             #include <sys/socket.h>
             int socket(int family,int type,int protocol);    
                  返回:非負描述字---成功   -1---失敗
             -----------------------------------------------------------------

            第一個參數指明了協議簇,目前支持5種協議簇,最常用的有AF_INET(IPv4協議)和AF_INET6(IPv6協議);第二個參數指明套接口類型,有三種類型可選:SOCK_STREAM(字節流套接口)、SOCK_DGRAM(數據報套接口)和SOCK_RAW(原始套接口);如果套接口類型不是原始套接口,那么第三個參數就為0。


            2、bind函數:為套接口分配一個本地IP和協議端口,對于網際協議,協議地址是32位IPv4地址或128位IPv6地址與16位的TCP或UDP端口號的組合;如指定端口為0,調用bind時內核將選擇一個臨時端口,如果指定一個通配IP地址,則要等到建立連接后內核才選擇一個本地IP地址。

            -------------------------------------------------------------------
            #include <sys/socket.h>  
             int bind(int sockfd, const struct sockaddr * server, socklen_t addrlen);
             返回:0---成功   -1---失敗 
             -------------------------------------------------------------------

              第一個參數是socket函數返回的套接口描述字;第二和第第三個參數分別是一個指向特定于協議的地址結構的指針和該地址結構的長度。


            3、recvfrom函數:UDP使用recvfrom()函數接收數據,他類似于標準的read(),但是在recvfrom()函數中要指明目的地址。

            -------------------------------------------------------------------
            #include <sys/types.h>  
            #include <sys/socket.h>  
            ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags, struct sockaddr * from, size_t *addrlen);
             返回接收到數據的長度---成功   -1---失敗 
             -------------------------------------------------------------------

              前三個參數等同于函數read()的前三個參數,flags參數是傳輸控制標志。最后兩個參數類似于accept的最后兩個參數。


            4、sendto函數:UDP使用sendto()函數發送數據,他類似于標準的write(),但是在sendto()函數中要指明目的地址。

            -------------------------------------------------------------------
            #include <sys/types.h>  
            #include <sys/socket.h>  
            ssize_t sendto(int sockfd, const void *buf, size_t len, int flags, const struct sockaddr * to, int addrlen);
             返回發送數據的長度---成功   -1---失敗 
             -------------------------------------------------------------------

              前三個參數等同于函數read()的前三個參數,flags參數是傳輸控制標志。參數to指明數據將發往的協議地址,他的大小由addrlen參數來指定。


            五、實驗步驟

            1、登陸進入ubuntu操作系統,新建一個文件,命名為udpserver.c(為了方便起見,可以進入“home”,再進入用戶目錄,在用戶目錄下新建udpserver.c)。

            2、在udpserver.c中編寫服務器端程序代碼并保存。

            3、在“終端”(“Applications”→“附件”→“終端”)中執行命令進入udpserver.c所在目錄。(pwd命令可以顯示當前所在目錄;ls命令可以顯示當前目錄下的文件和文件夾信息;cd..命令可以進入上一級目錄;cd 目錄名 命令可以進入當前所示的某個目錄。)

            4、執行命令gcc –o udpserver udpserver.c生成可執行文件udpserver。

            5、執行命令./ udpserver,觀察結果。

            6、認真分析源代碼,體會如何編寫一個UDP服務器端程序。

             

            六、參考程序(udpserver.c

            1. #include<stdio.h>  
            2.       #include<string.h>  
            3.       #include<unistd.h>  
            4.       #include<sys/types.h>  
            5.       #include<sys/socket.h>  
            6.       #include<stdlib.h>  
            7.       #include<netinet/in.h>  
            8.       #include<arpa/inet.h>  
            9.   
            10.       #define PORT 1234  
            11.       #define MAXDATASIZE 100  
            12.   
            13.       main()  
            14.       {  
            15.       int sockfd;  
            16.       struct sockaddr_in server;  
            17.       struct sockaddr_in client;  
            18.       socklen_t addrlen;  
            19.       int num;  
            20.       char buf[MAXDATASIZE];  
            21.   
            22.       if((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1)   
            23.       {  
            24.       perror("Creatingsocket failed.");  
            25.       exit(1);  
            26.       }  
            27.   
            28.       bzero(&server,sizeof(server));  
            29.       server.sin_family=AF_INET;  
            30.       server.sin_port=htons(PORT);  
            31.       server.sin_addr.s_addr= htonl (INADDR_ANY);  
            32.       if(bind(sockfd, (struct sockaddr *)&server, sizeof(server)) == -1)  
            33.       {  
            34.       perror("Bind()error.");  
            35.       exit(1);  
            36.       }     
            37.   
            38.       addrlen=sizeof(client);  
            39.       while(1)    
            40.       {  
            41.       num =recvfrom(sockfd,buf,MAXDATASIZE,0,(struct sockaddr*)&client,&addrlen);                                     
            42.   
            43.       if (num < 0)  
            44.       {  
            45.       perror("recvfrom() error\n");  
            46.       exit(1);  
            47.       }  
            48.   
            49.       buf[num] = '\0';  
            50.       printf("You got a message (%s%) from client.\nIt's ip is%s, port is %d.\n",buf,inet_ntoa(client.sin_addr),htons(client.sin_port));   
            51.       sendto(sockfd,"Welcometo my server.\n",22,0,(struct sockaddr *)&client,addrlen);  
            52.       if(!strcmp(buf,"bye"))  
            53.       break;  
            54.       }  
            55.       close(sockfd);    
            56.       }  


             

                  實驗四 UDP客戶端程序設計

            一、實驗目的

            學習和掌握Linux下的UDP客戶端基本原理和基本編程方法。

            二、實驗平臺

            ubuntu-8.04操作系統

            三、實驗內容

            編寫Linux下UDP客戶端套接字程序,結合實驗三的UDP服務器端程序,實現以下功能:

            1、客戶根據用戶提供的IP地址將用戶從終端輸入的信息發送給服務器,然后等待服務器的回應。

            2、服務器接收客戶端發送的信息并顯示,同時顯示客戶的IP地址、端口號,并向客戶端發送信息。如果服務器接收的客戶信息為“bye”,則退出循環,并關閉套接字。

            3、客戶接收、顯示服務器發回的信息,并關閉套接字。

            四、實驗原理

            見實驗三的實驗原理部分。

            五、實驗步驟

            1、登陸進入ubuntu操作系統,新建一個文件,命名為udpclient.c(為了方便起見,可以進入“home”,再進入用戶目錄,在用戶目錄下新建udpclient.c)。

            2、在udpclient.c中編寫客戶端程序代碼并保存。將實驗三完成的udpserver.c拷貝到與udpclient.c同一目錄下。

            3、在“終端”(“Applications”→“附件”→“終端”)中執行命令進入udpserver.c和udpclient.c所在目錄。

            4、執行命令gcc –o udpserver udpserver.c生成可執行文件udpserver。

            5、執行命令./ udpserver。

            6、再開一個“終端”,進入udpserver.c和udpclient.c所在目錄,執行命令

            gcc–o udpclient udpclient.c生成可執行文件udpclient。

            7、執行命令./ udpclient 127.0.0.1 hello。

            8、觀察兩個“終端”出現的結果。

            9、在客戶端終端下執行命令./ udpclient 127.0.0.1 bye。

            10、觀察兩個“終端”出現的結果。

            11、認真分析源代碼,體會如何編寫一個UDP客戶端程序。

             

            六、參考程序(udpclient.c

                 

            1. #include <stdio.h>  
            2.      #include <stdlib.h>  
            3.      #include <unistd.h>  
            4.      #include <string.h>  
            5.      #include <sys/types.h>  
            6.      #include <sys/socket.h>  
            7.      #include <netinet/in.h>  
            8.      #include <netdb.h>  
            9.   
            10.      #define PORT 1234  
            11.      #define MAXDATASIZE 100  
            12.   
            13.      int main(int argc, char *argv[])  
            14.      {  
            15.      int sockfd, num;  
            16.      char buf[MAXDATASIZE];  
            17.   
            18.      struct hostent *he;  
            19.      struct sockaddr_in server,peer;  
            20.   
            21.      if (argc !=3)  
            22.      {  
            23.      printf("Usage: %s <IP Address><message>\n",argv[0]);  
            24.      exit(1);  
            25.      }  
            26.   
            27.      if ((he=gethostbyname(argv[1]))==NULL)  
            28.      {  
            29.      printf("gethostbyname()error\n");  
            30.      exit(1);  
            31.      }  
            32.   
            33.      if ((sockfd=socket(AF_INET, SOCK_DGRAM,0))==-1)  
            34.      {  
            35.      printf("socket() error\n");  
            36.      exit(1);  
            37.      }  
            38.   
            39.      bzero(&server,sizeof(server));  
            40.      server.sin_family = AF_INET;  
            41.      server.sin_port = htons(PORT);  
            42.      server.sin_addr= *((struct in_addr *)he->h_addr);  
            43.      sendto(sockfd, argv[2],strlen(argv[2]),0,(struct sockaddr *)&server,sizeof(server));  
            44.      socklen_t  addrlen;  
            45.      addrlen=sizeof(server);  
            46.      while (1)  
            47.      {  
            48.      if((num=recvfrom(sockfd,buf,MAXDATASIZE,0,(struct sockaddr *)&peer,&addrlen))== -1)  
            49.      {  
            50.      printf("recvfrom() error\n");  
            51.      exit(1);  
            52.      }  
            53.      if (addrlen != sizeof(server) ||memcmp((const void *)&server, (const void *)&peer,addrlen) != 0)  
            54.      {  
            55.      printf("Receive message from otherserver.\n");  
            56.      continue;  
            57.      }  
            58.   
            59.      buf[num]='\0';  
            60.      printf("Server Message:%s\n",buf);  
            61.      break;  
            62.      }  
            63.   
            64.      close(sockfd);  
            65.      }  

             

            UDP實驗結果:

            服務器端:


            客戶端:


            posted on 2012-07-05 14:26 tqsheng 閱讀(886) 評論(0)  編輯 收藏 引用

            亚洲精品乱码久久久久久蜜桃| 亚洲伊人久久成综合人影院 | 亚洲国产精品婷婷久久| 99久久无色码中文字幕| 国产99久久九九精品无码| 国产精品九九久久免费视频| 欧美日韩中文字幕久久久不卡 | 国产精品美女久久久久av爽| 国产精品成人99久久久久 | 国产aⅴ激情无码久久| 国产午夜久久影院| 久久久久亚洲?V成人无码| 精品久久久久久久久久中文字幕| 亚洲国产精品人久久| 亚洲国产小视频精品久久久三级| 天天躁日日躁狠狠久久| 狠狠色伊人久久精品综合网| 色老头网站久久网| 91久久精品91久久性色| 日批日出水久久亚洲精品tv| 精品久久8x国产免费观看| 青青热久久国产久精品| 久久精品国产精品亚洲精品| 2021国产精品午夜久久| 狠狠久久综合伊人不卡| 国产精品一区二区久久| 伊人久久大香线蕉综合影院首页| 久久黄色视频| 久久久综合九色合综国产| 伊人久久大香线焦AV综合影院| 久久久精品日本一区二区三区| 精品熟女少妇av免费久久| 狠狠色婷婷久久一区二区 | 久久这里只有精品首页| 久久亚洲欧洲国产综合| 国产免费久久精品丫丫| 久久久久四虎国产精品| 69久久夜色精品国产69| 久久精品国产精品国产精品污| 久久99精品国产麻豆| 久久福利青草精品资源站免费|