freshbug's notes

freshbug的代码人生

bekilledlzyID:bekilledlzy
[修改头像]
12135次访问,排名8272(-5)好友0人,关注者0
bekilledlzy的文章
原创 17 篇
翻译 0 篇
转载 32 篇
评论 6 篇
freshbug的公告
访问www.freshbug.com
自2007年10月16日
freshbug的联系方式:
freshbug@gmail.com
最近评论
loadend:你好,我想问一下,那注册google ad帐户的时候不是要填网址嘛,填什么呢?是不是填http://blog.csdn.net/用户名/??
freshbug:stl里面有一些静态变量 不能跨dll vector有时候能跨dll是因为连续的内存分布

跨模块传输数据最好是能用C风格的结构 用C++类很容易出问题
wang:我是向dll中传一个map指针,结果也是it++之后就内存泄漏
wang:我也遇到了类似问题。
远离尘嚣:老大,能把你的Uft8ToAnsi是自定义的转码函数共享一下嘛?万分感谢!
软件项目交易
订阅我的博客
XML聚合  FeedSky
订阅到鲜果
订阅到Google
订阅到抓虾
订阅到BlogLines
订阅到Yahoo
订阅到GouGou
订阅到飞鸽
订阅到Rojo
订阅到newsgator
订阅到netvibes
文章分类
收藏
    相册
    who's freshbug?
    技术站点
    老牛们的blog
    咨讯
    存档

    转载 Linux开发服务器的常用socket代码

    新一篇: 我怎样才能嫁给有钱人?

    经常用到的几个自定义函数:
    1、开启监听的函数

    http://linux.chinaunix.net/bbs/viewthread.php?tid=786283&extra=


    1. /*----------------------源代码代码开始--------------------------------------------*/  
    2. int  
    3. OpenSCPServer(int port, int total, int sendbuflen, int recvbuflen, int blockORnot, int reuseORnot)    {   
    4. /*************************关于本函数************************************  
    5. *function_name: OpenSCPServer  
    6. *参数说明:port整数型监听端口号,total整数型监听个数,sendbuflen整数型发送缓冲区大小  
    7. *          recvbuflen整数型接收缓冲区大小,blockORnot整数型是否阻塞,reuseORnot整数型是否端口重用  
    8. *purpose: 用来建立一个tcp服务端socket  
    9. *tidied by: zhoulifa(zhoulifa@163.com) 周立发(http://zhoulifa.9999mb.com)  
    10. Linux爱好者 Linux知识传播者 SOHO族 开发者 最擅长C语言  
    11. *date time:2006-07-05 20:00:00  
    12. *Note: 任何人可以任意复制代码并运用这些文档,当然包括你的商业用途  
    13. * 但请遵循GPL  
    14. *Thanks to: Paul Sheer 感谢Paul Sheer在select_tut的man手册里提供了这份源代码  
    15. *Hope:希望越来越多的人贡献自己的力量,为科学技术发展出力  
    16. *Note:要使用此函数需要自定义一个全局变量char errorMessage[1024];并包含GetCurrentTime.h头文件  
    17. *********************************************************************/  
    18.     int    sockfd = 0, ret = 0, opt = 0, flags=1;   
    19.     struct sockaddr_in    laddr;   
    20.   
    21.     ret = sockfd = socket(PF_INET, SOCK_STREAM, 0);   
    22.     if(ret < 0)    {   
    23.         sprintf(errorMessage, "OpenTCPServer socket() error! return:%d, errno=%d, errortext:'%s' %s", ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    24.         return -1;   
    25.     }   
    26.   
    27.     ret = setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &reuseORnot, sizeof(int));   
    28.     if(ret < 0)    {   
    29.         sprintf(errorMessage, "OpenTCPServer setsockopt() reuse error! return:%d, errno=%d, errortext:'%s' %s", ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    30.         return -2;   
    31.     }   
    32.   
    33.     ret = setsockopt(sockfd, SOL_SOCKET, SO_RCVBUF, &recvbuflen, sizeof(int));   
    34.     if ( ret < 0)    {   
    35.         sprintf(errorMessage, "OpenTCPServer setsockopt() recvbuf error! return:%d, errno=%d, errortext:'%s' %s", ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    36.         return -3;   
    37.     }   
    38.   
    39.     ret = setsockopt(sockfd, SOL_SOCKET, SO_SNDBUF, &sendbuflen, sizeof(int));   
    40.     if (ret < 0)    {   
    41.         sprintf(errorMessage, "OpenTCPServer setsockopt() sendbuf error! return:%d, errno=%d, errortext:'%s' %s", ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    42.         return -4;   
    43.     }   
    44.   
    45.     ioctl(sockfd,FIONBIO,&blockORnot);/*block or not*/  
    46.   
    47.     laddr.sin_family = PF_INET;   
    48.     laddr.sin_port = htons(port);   
    49.     laddr.sin_addr.s_addr = INADDR_ANY;   
    50.     bzero(&(laddr.sin_zero), 8);   
    51.   
    52.     ret = bind(sockfd, (struct sockaddr *)&laddr, sizeof(struct sockaddr));   
    53.     if(ret < 0)    {   
    54.         sprintf(errorMessage, "OpenTCPServer bind() error! return:%d, errno=%d, errortext:'%s' %s", ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    55.         close(sockfd);   
    56.         return -5;   
    57.     }   
    58.     ret = listen(sockfd, total);   
    59.     if(ret < 0)    {   
    60.         sprintf(errorMessage, "OpenTCPServer listen() error! return:%d, errno=%d, errortext:'%s' %s", ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    61.         close(sockfd);   
    62.         return -6;   
    63.     }   
    64.     sprintf(errorMessage, "OpenTCPServer opened on port.%d(%d) OK, socket(%d), buf(%d:%d)! %s", port, total, sockfd, sendbuflen, recvbuflen, GetCurrentTime(0, 0));   
    65.     return sockfd;   
    66. }   
    67. /*----------------------源代码代码结束--------------------------------------------*/  


    2、连接服务器的函数

    1. /*----------------------源代码代码开始--------------------------------------------*/  
    2. int  
    3. ConnectSCPServer(char * serverip, int serverport, int blockORnot)    {   
    4. /*************************关于本函数************************************  
    5. *function_name: ConnectSCPServer  
    6. *参数说明:serverip服务器IP地址或主机名,serverport服务器端口,blockORnot整数型是否阻塞  
    7. *purpose: 用来建立一个tcp客户端socket  
    8. *tidied by: zhoulifa(zhoulifa@163.com) 周立发(http://zhoulifa.9999mb.com)  
    9. Linux爱好者 Linux知识传播者 SOHO族 开发者 最擅长C语言  
    10. *date time:2006-07-05 20:40:00  
    11. *Note: 任何人可以任意复制代码并运用这些文档,当然包括你的商业用途  
    12. * 但请遵循GPL  
    13. *Thanks to: Paul Sheer 感谢Paul Sheer在select_tut的man手册里提供了这份源代码  
    14. *Hope:希望越来越多的人贡献自己的力量,为科学技术发展出力  
    15. *Note:要使用此函数需要自定义一个全局变量char errorMessage[1024];并包含自己编写的GetCurrentTime.h头文件  
    16. *********************************************************************/  
    17.     int    serversock = 0, ret = 0;   
    18.     unsigned long    addr;   
    19.     struct sockaddr_in    sin;   
    20.     struct hostent *he;   
    21.   
    22.     if((he=gethostbyname(serverip))== 0) {   
    23.         sprintf(errorMessage, "ConnectSCPServer IP address '%s' error! return:-1 %s", serverip, GetCurrentTime(0, 0));   
    24.         return -1;   
    25.     }   
    26.   
    27.     serversock = socket(PF_INET, SOCK_STREAM, 0);   
    28.     if(serversock == -1)    {   
    29.         sprintf(errorMessage, "ConnectSCPServer socket() error! return:-2, errno=%d, errortext:'%s' %s", errno, strerror(errno), GetCurrentTime(0, 0));   
    30.         return -2;   
    31.     }   
    32.   
    33.     ioctl(serversock, FIONBIO, &blockORnot);  //block or not   
    34.   
    35.     memset((char*)&sin, 0, sizeof(struct sockaddr_in));   
    36.     sin.sin_family = PF_INET;   
    37.     sin.sin_port = htons(serverport);   
    38.     sin.sin_addr = *((struct in_addr *)he->h_addr);   
    39.   
    40.     ret = connect(serversock, (struct sockaddr *)&sin, sizeof(sin));   
    41.   
    42.     if(ret == -1)    {   
    43.         sprintf(errorMessage, "ConnectSCPServer connect() error! return:-3, errno=%d, errortext:'%s' %s", errno, strerror(errno), GetCurrentTime(0, 0));   
    44.         close(serversock);   
    45.         return -3;   
    46.     }   
    47.   
    48.     return serversock;   
    49. }   
    50. /*----------------------源代码代码结束--------------------------------------------*/  


    3、发送数据函数Send

    1. /*----------------------源代码代码开始--------------------------------------------*/  
    2. int  
    3. Send(int sock, char * buf, size_t size, int flag, int timeout)    {   
    4. /*************************关于本函数************************************  
    5. *function_name: Send  
    6. *参数说明:sock整数型socket,buf待发送的内容,size要发送的大小,flag发送选项,timeout超时时间值  
    7. *purpose: 用来通过一个socket在指定时间内发送数据  
    8. *tidied by: zhoulifa(zhoulifa@163.com) 周立发(http://zhoulifa.9999mb.com)  
    9. Linux爱好者 Linux知识传播者 SOHO族 开发者 最擅长C语言  
    10. *date time:2006-07-05 20:58:00  
    11. *Note: 任何人可以任意复制代码并运用这些文档,当然包括你的商业用途  
    12. * 但请遵循GPL  
    13. *Thanks to: Paul Sheer 感谢Paul Sheer在select_tut的man手册里提供了这份源代码  
    14. *Hope:希望越来越多的人贡献自己的力量,为科学技术发展出力  
    15. *Note:要使用此函数需要自定义一个全局变量char errorMessage[1024];并包含自己编写的GetCurrentTime.h头文件  
    16. *********************************************************************/  
    17.     int i = 0, ret = 0, intretry = 0;   
    18.   
    19.     struct timeval tival;   
    20.     fd_set writefds;   
    21.     int maxfds = 0;   
    22.   
    23.     tival.tv_sec = timeout;   
    24.     tival.tv_usec = 0;   
    25.   
    26.     FD_ZERO(&writefds);   
    27.   
    28.     if(sock > 0) {   
    29.         FD_SET(sock, &writefds);   
    30.         maxfds=((sock > maxfds)?sock:maxfds);   
    31.     }   
    32.     else    {   
    33.         sprintf(errorMessage, "Send socket:%d error! return:-2 %s", sock, GetCurrentTime(0, 0));   
    34.         return -2;   
    35.     }   
    36.   
    37.     ret = select(maxfds + 1, NULL, &writefds, NULL, &tival);   
    38.     if(ret <= 0) {   
    39.         if(ret < 0)    sprintf(errorMessage, "Send socket:%d select() error! return:%d, errno=%d, errortext:'%s' %s", sock, ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    40.         else sprintf(errorMessage, "Send socket:%d select timeout(%d)! %s", sock, timeout, GetCurrentTime(0, 0));   
    41.         close(sock);   
    42.         return -3;   
    43.     }   
    44.     if(!(FD_ISSET(sock, &writefds)))    {   
    45.         sprintf(errorMessage, "Send socket:%d not in writefds! %s", sock, GetCurrentTime(0, 0));   
    46.         close(sock);   
    47.         return -4;   
    48.     }   
    49.   
    50.     while(i < size)    {   
    51.         ret = send(sock, buf + i, size - i, flag);   
    52.         if(ret <= 0)    {   
    53.             sprintf(errorMessage, "Send socket:%d send() error! return:%d, errno=%d, errortext:'%s' %s", sock, ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    54.   
    55.             if (EINTR == errno)   
    56.               if(intretry < 10)  {intretry++;continue;}   
    57.               else sprintf(errorMessage, "Send socket:%d send() error!EINTR 10 times! %s", sock, GetCurrentTime(0, 0));   
    58.   
    59.             close(sock);   
    60.             return -1;   
    61.         }   
    62.         else i += ret;   
    63.     }   
    64.     sprintf(errorMessage, "Send socket:%d send() OK! %d/%d bytes sent! %s", sock, i, size, GetCurrentTime(0, 0));   
    65.     return i;   
    66. }   
    67. /*----------------------源代码代码结束--------------------------------------------*/  
    68.   

    接收数据函数Recv
    1. /*----------------------源代码代码开始--------------------------------------------*/  
    2. int  
    3. Recv(int sock, char * buf, size_t size, int flag, int timeout)    {   
    4. /*************************关于本函数************************************  
    5. *function_name: Recv  
    6. *参数说明:sock整数型socket,buf接收数据的缓冲区,size要接收数据的大小,flag接收选项,timeout超时时间值  
    7. *purpose: 用来从一个socket在指定时间内读取数据  
    8. *tidied by: zhoulifa(zhoulifa@163.com) 周立发(http://zhoulifa.9999mb.com)  
    9. Linux爱好者 Linux知识传播者 SOHO族 开发者 最擅长C语言  
    10. *date time:2006-07-05 21:10:00  
    11. *Note: 任何人可以任意复制代码并运用这些文档,当然包括你的商业用途  
    12. * 但请遵循GPL  
    13. *Thanks to: Paul Sheer 感谢Paul Sheer在select_tut的man手册里提供了这份源代码  
    14. *Hope:希望越来越多的人贡献自己的力量,为科学技术发展出力  
    15. *Note:要使用此函数需要自定义一个全局变量char errorMessage[1024];并包含自己编写的GetCurrentTime.h头文件  
    16. *********************************************************************/  
    17.     int i = 0, ret = 0, intretry = 0;   
    18.   
    19.     struct timeval tival;   
    20.     fd_set readfds;   
    21.     int maxfds = 0;   
    22.   
    23.     tival.tv_sec = timeout;   
    24.     tival.tv_usec = 0;   
    25.   
    26.     FD_ZERO(&readfds);   
    27.   
    28.     if(sock > 0) {   
    29.         FD_SET(sock, &readfds);   
    30.         maxfds=((sock > maxfds)?sock:maxfds);   
    31.     }   
    32.     else    {   
    33.         sprintf(errorMessage, "Recv socket:%d error! return:-2 %s", sock, GetCurrentTime(0, 0));   
    34.         return -2;   
    35.     }   
    36.   
    37.     ret = select(maxfds + 1, &readfds, NULL, NULL, &tival);   
    38.     if(ret <= 0) {   
    39.         if(ret < 0)    sprintf(errorMessage, "Recv socket:%d select() error! return:%d, errno=%d, errortext:'%s' %s", sock, ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    40.         else sprintf(errorMessage, "Recv socket:%d select timeout(%d)! %s", sock, timeout, GetCurrentTime(0, 0));   
    41.         close(sock);   
    42.         return -3;   
    43.     }   
    44.     if(!(FD_ISSET(sock, &readfds)))    {   
    45.         sprintf(errorMessage, "Recv socket:%d not in readfds! %s", sock, GetCurrentTime(0, 0));   
    46.         close(sock);   
    47.         return -4;   
    48.     }   
    49.     while(i < size)    {   
    50.         ret = recv(sock, buf + i, size - i, flag);   
    51.         if(ret <= 0){   
    52.             sprintf(errorMessage, "Recv socket:%d recv() error! return:%d, errno=%d, errortext:'%s' %s", sock, ret, errno, strerror(errno), GetCurrentTime(0, 0));   
    53.             if(errno == EINTR)      
    54.                 if(intretry < 10)  {intretry++;continue;}   
    55.                 else sprintf(errorMessage, "Recv socket:%d recv() error! EINTR 10 times! %s", sock, GetCurrentTime(0, 0));   
    56.             close(sock);   
    57.             return -1;   
    58.         }   
    59.         else i += ret;   
    60.     }   
    61.     sprintf(errorMessage, "Recv socket:%d recv() OK! %d/%d bytes received! %s", sock, i, size, GetCurrentTime(0, 0));   
    62.     return i;   
    63. }   


    Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1807179

     

    发表于 @ 2007年10月10日 01:07:00|评论(loading...)|编辑

    旧一篇: CMD下开启2003的3389

    评论:没有评论。

    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © freshbug