• <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>
            隨筆 - 60, 文章 - 0, 評(píng)論 - 197, 引用 - 0
            數(shù)據(jù)加載中……

            Linux 下 socket 編程示例

            本示例為 Client/Server 結(jié)構(gòu),通過(guò)代碼演示 Client 如何建立連接,并向遠(yuǎn)程端發(fā)送數(shù)據(jù);Server 端如何偵聽(tīng)系統(tǒng)連接請(qǐng)求,接收請(qǐng)求并建立連接,進(jìn)而獲取客戶(hù)端發(fā)來(lái)的數(shù)據(jù)。代碼雖短,卻描述了整個(gè)通信過(guò)程,可對(duì)Linux 下 網(wǎng)絡(luò)編程起個(gè)拋磚引玉的作用吧 :-)

            Client 端代碼:
            --------------------------------------------------------------
            /* sockclnt.c*/
            #include <string.h>
            #include <stdlib.h>
            #include <sys/types.h>
            #include <sys/socket.h>
            #include <netinet/in.h> /*for struct sockaddr_in*/

            #define DEST_IP   "65.52.207.217"
            #define DEST_PORT 4000

            int main()
            {
              int res;
              int sockfd;
              struct sockaddr_in dest_addr;

              char *msg = "Hello world\n";
              int len, bytes_sent;

              /* 取得一個(gè)套接字*/
              sockfd = socket(AF_INET, SOCK_STREAM, 0);
              if (sockfd == -1) {
                perror("socket()");
                exit(1);
              }

              /* 設(shè)置遠(yuǎn)程連接的信息*/
              dest_addr.sin_family = AF_INET;                 /* 注意主機(jī)字節(jié)順序*/
              dest_addr.sin_port = htons(DEST_PORT);          /* 遠(yuǎn)程連接端口, 注意網(wǎng)絡(luò)字節(jié)順序*/
              dest_addr.sin_addr.s_addr = inet_addr(DEST_IP); /* 遠(yuǎn)程 IP 地址, inet_addr() 會(huì)返回網(wǎng)絡(luò)字節(jié)順序*/
              bzero(&(dest_addr.sin_zero), 8);                /* 其余結(jié)構(gòu)須置 0*/

              /* 連接遠(yuǎn)程主機(jī),出錯(cuò)返回 -1*/
              res = connect(sockfd, (struct sockaddr *)&dest_addr, sizeof(struct sockaddr_in));
              if (res == -1) {
                perror("connect()");
                exit(1);
              }

              len = strlen(msg);
              bytes_sent = send(sockfd, /* 連接描述符*/
                                msg,    /* 發(fā)送內(nèi)容*/
                                len,    /* 發(fā)關(guān)內(nèi)容長(zhǎng)度*/
                                0);     /* 發(fā)送標(biāo)記, 一般置 0*/

              /* 關(guān)閉連接*/
              close(sockfd);
            }


            Server 端的代碼:
            -----------------------------------------------------------------------------------------
            /* socksrv.c*/
            #include <stdio.h>
            #include <stdlib.h>
            #include <string.h>
            #include <sys/types.h>
            #include <sys/socket.h>
            #include <netinet/in.h> /* for struct sockaddr_in*/

            #define BACKLOG 10
            #define MYPORT  4000

            int main()
            {
              char *addr;
              int sockfd;
              int new_fd;
              struct sockaddr_in my_addr, their_addr;

              int res;
              int sin_size;

              char *buf;
              /* 取得套接字描述符*/
              sockfd = socket(AF_INET,     /* domain*/
                              SOCK_STREAM, /* type*/
                              0);          /* protocol*/

              if (sockfd == -1) {
                perror("socket");
                exit(1);
              }

              /* Init sockaddr_in */
              my_addr.sin_family = AF_INET;                /* 注意: 應(yīng)使用主機(jī)字節(jié)順序*/
              my_addr.sin_port = htons(MYPORT);            /* 注意: 應(yīng)使用網(wǎng)絡(luò)字節(jié)順序*/
              my_addr.sin_addr.s_addr = htonl(INADDR_ANY); /* 使用自己的 IP 地址 */
              bzero(&(my_addr.sin_zero), 8);               /* 結(jié)構(gòu)的其余的部分須置 0*/

              /* 指定一個(gè)套接字使用的地址及端口*/
              res = bind(sockfd, (struct sockaddr*)&my_addr, sizeof(struct sockaddr));
              if (res == -1) {
                perror("bind");
                exit(1);
              }

              /* 監(jiān)聽(tīng)請(qǐng)求, 等待連接*/
              res = listen(sockfd,
                           BACKLOG);  /* 未經(jīng)處理的連接請(qǐng)求隊(duì)列可容納的最大數(shù)目*/               
              if (res == -1) {
                perror("listen");
                exit(1);
              }

              /* 接受對(duì)方的連接請(qǐng)求, 建立連接,返回一個(gè)新的連接描述符.
               * 而第一個(gè)套接字描述符仍在你的機(jī)器上原來(lái)的端口 listen()
               */
              sin_size = sizeof(struct sockaddr_in);
              new_fd = accept(sockfd, (void *)&their_addr, &sin_size);

              buf = (char *)malloc(255);
              if (buf == NULL) {
                printf("malloc failed\n");
                exit(1);
              }

              /* 接受對(duì)方發(fā)來(lái)的數(shù)據(jù)*/
              res = recv(new_fd, buf, 255, 0);
              if (res == -1) {
                perror("recv()");
                exit(1);
              }

              /* 關(guān)閉本次連接*/
              close(new_fd);

              /* 關(guān)閉系統(tǒng)監(jiān)聽(tīng)*/
              close(sockfd);

              printf("recv data:%s\n", buf);
              free(buf);
              return 0;
            }

            編譯:
            ------------------------------------------------
            gcc -o sockclnt sockclnt.c
            gcc -o socksrv  socksrv.c




            posted on 2008-08-02 16:03 Normandy 閱讀(11261) 評(píng)論(5)  編輯 收藏 引用 所屬分類(lèi): Networking

            評(píng)論

            # re: Linux 下 socket 編程示例  回復(fù)  更多評(píng)論   

            呵呵,我在WINDOWS下也做過(guò)一個(gè)類(lèi)似,不幾乎是一模一樣的SOCKET通訊,呵呵,看著代碼怎么跟我的一樣?哈哈,畢竟是按照TCP/IP協(xié)議寫(xiě)的嘛,難免有似曾相識(shí)的感覺(jué),我的代碼在 http://hi.baidu.com/alexeric.
            2008-08-07 08:47 | AlexEric

            # re: Linux 下 socket 編程示例  回復(fù)  更多評(píng)論   

            @AlexEric
            兄弟對(duì) TCP/IP 也有興趣啊,我打算通讀 Linux 下的協(xié)議棧源碼,有機(jī)會(huì)多切磋啊 :-)
            2008-08-07 10:46 | Normandy

            # re: Linux 下 socket 編程示例  回復(fù)  更多評(píng)論   

            從純技術(shù)的角度來(lái)講,能夠通讀 Linux 下的協(xié)議棧源碼對(duì)于Normandy 兄來(lái)說(shuō),是一件很享受的事情,但在俺看來(lái),這東西也是求得工作立足之本的呀。
            只不過(guò)俺現(xiàn)在不從事TCP/IP,看源碼很累人。

            Normandy 兄可以考慮開(kāi)源,參與開(kāi)源軟件的開(kāi)發(fā),在開(kāi)發(fā)中學(xué)習(xí)TCP/IP豈不更爽哉?
            2008-08-07 11:35 | AlexEric

            # re: Linux 下 socket 編程示例  回復(fù)  更多評(píng)論   

            @AlexEric
            看情況吧,只恐時(shí)間精力不夠用。參與開(kāi)源著重解決實(shí)際問(wèn)題,分析 Kernel 源碼則強(qiáng)調(diào)理解底層,我更喜歡看些底層的東西。

            AlexEric 兄若有心得,一定要拿出來(lái)分享啊!
            2008-08-07 12:22 | Normandy

            # re: Linux 下 socket 編程示例  回復(fù)  更多評(píng)論   

            其實(shí),寫(xiě)遠(yuǎn)比看好。
            所以兄臺(tái)你要真要有所得,還是自己寫(xiě)代碼吧,哪怕是模仿。
            2008-08-07 21:02 | AlexEric
            伊人久久大香线焦AV综合影院| 久久99国产精品99久久| 国产日韩久久免费影院| 国产成人久久激情91| 久久精品中文字幕有码| 中文字幕无码久久精品青草| 亚洲精品乱码久久久久久按摩| 久久精品国产亚洲AV麻豆网站| 国产精品免费久久| 亚洲国产婷婷香蕉久久久久久| 97久久婷婷五月综合色d啪蜜芽 | 国产精品久久久久影院色| 99久久www免费人成精品| 国产69精品久久久久APP下载 | 无码人妻久久一区二区三区蜜桃| 伊人久久一区二区三区无码| 久久久久亚洲AV成人片| 久久国产视屏| 久久91综合国产91久久精品| 国产精品久久久久久久app | 99久久婷婷国产综合精品草原| 99久久香蕉国产线看观香| 久久亚洲欧美日本精品| 久久久久久久久久久久久久| 久久99精品久久久久久不卡| 国产精品女同久久久久电影院| 久久精品二区| 久久香蕉国产线看观看99| 最新久久免费视频| 国产精品女同一区二区久久| 97久久精品无码一区二区| 国产偷久久久精品专区| 性高朝久久久久久久久久| 国内精品久久久久国产盗摄| 久久久久久久久无码精品亚洲日韩 | 国产国产成人久久精品| 久久久久久毛片免费播放| 亚洲AV成人无码久久精品老人| 亚洲欧美一区二区三区久久| 亚洲精品无码久久不卡| 久久丝袜精品中文字幕|