14、TCP网络程序设计

news/2024/5/17 15:51:04 标签: tcp, 网络, struct, server, socket, buffer
 

              基于TCP—服务器

Ø         创建一个socket,用函数socket()

Ø         绑定IP地址,端口等信息到socket上,用函数bind()

Ø         设置允许最大连接数 ,用函数listen()

Ø         等待来自客户端的连接请求,用函数accept()

Ø         收发数据,用函数send()和recv(),或者read()和write()

Ø         关闭网络连接

       基于TCP—客户端

²        创建一个socket,用函数socket()

²        设置要连接的服务器的IP地址和端口等属性

²        连接服务器,用函数connect()

²        收发数据,用函数send()和recv),或者read()和write()

²        关闭网络连接

       例题1:tcp_server.c

#include <stdlib.h>

#include <stdio.h>

#include <errno.h>

#include <string.h>

#include <netdb.h>

#include <sys/types.h>

#include <netinet/in.h>

#include <sys/socket.h>

 

#define portnumber 3333

 

int main(int argc, char *argv[])

{

    int sockfd,new_fd;

    struct sockaddr_in server_addr;

    struct sockaddr_in client_addr;

    int sin_size;

    int nbytes;

    char buffer[1024];

   

 

    /* 服务器端开始建立sockfd描述符 */

    if((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1) // AF_INET:IPV4;SOCK_STREAM:TCP

    {

        fprintf(stderr,"Socket error:%s\n\a",strerror(errno));

        exit(1);

    }

 

    /* 服务器端填充 sockaddr结构 */

    bzero(&server_addr,sizeof(struct sockaddr_in)); // 初始化,置0

    server_addr.sin_family=AF_INET;                 // Internet

    server_addr.sin_addr.s_addr=htonl(INADDR_ANY);  // (将本机器上的long数据转化为网络上的long数据)和任何主机通信  //INADDR_ANY 表示可以接收任意IP地址的数据,即绑定到所有的IP

    //server_addr.sin_addr.s_addr=inet_addr("192.168.1.1");  //用于绑定到一个固定IP,inet_addr用于把数字加格式的ip转化为整形ip

    server_addr.sin_port=htons(portnumber);         // (将本机器上的short数据转化为网络上的short数据)端口号

   

    /* 捆绑sockfd描述符到IP地址 */

    if(bind(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1)

    {

        fprintf(stderr,"Bind error:%s\n\a",strerror(errno));

        exit(1);

    }

 

    /* 设置允许连接的最大客户端数 */

    if(listen(sockfd,5)==-1)

    {

        fprintf(stderr,"Listen error:%s\n\a",strerror(errno));

        exit(1);

    }

 

    while(1)

    {

        /* 服务器阻塞,直到客户程序建立连接 */

        sin_size=sizeof(struct sockaddr_in);

        if((new_fd=accept(sockfd,(struct sockaddr *)(&client_addr),&sin_size))==-1)

        {

            fprintf(stderr,"Accept error:%s\n\a",strerror(errno));

            exit(1);

        }

        fprintf(stderr,"Server get connection from %s\n",inet_ntoa(client_addr.sin_addr)); // 将网络地址转换成.字符串

       

        if((nbytes=read(new_fd,buffer,1024))==-1)

        {

            fprintf(stderr,"Read Error:%s\n",strerror(errno));

            exit(1);

        }      

        buffer[nbytes]='\0';

        printf("Server received %s\n",buffer);

       

        /* 这个通讯已经结束 */

        close(new_fd);

        /* 循环下一个 */

    }

 

    /* 结束通讯 */

    close(sockfd);

    exit(0);

}

 

  

 

 

 

 

                                                 Tcp_client.c

#include <stdlib.h>

#include <stdio.h>

#include <errno.h>

#include <string.h>

#include <netdb.h>

#include <sys/types.h>

#include <netinet/in.h>

#include <sys/socket.h>

 

#define portnumber 3333

 

int main(int argc, char *argv[])

{

    int sockfd;

    char buffer[1024];

    struct sockaddr_in server_addr;

    struct hostent *host;

 

        /* 使用hostname查询host 名字 */

    if(argc!=2)

    {

        fprintf(stderr,"Usage:%s hostname \a\n",argv[0]);

        exit(1);

    }

 

    if((host=gethostbyname(argv[1]))==NULL)

    {

        fprintf(stderr,"Gethostname error\n");

        exit(1);

    }

 

    /* 客户程序开始建立 sockfd描述符 */

    if((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1) // AF_INET:Internet;SOCK_STREAM:TCP

    {

        fprintf(stderr,"Socket Error:%s\a\n",strerror(errno));

        exit(1);

    }

 

    /* 客户程序填充服务端的资料 */

    bzero(&server_addr,sizeof(server_addr)); // 初始化,置0

    server_addr.sin_family=AF_INET;          // IPV4

    server_addr.sin_port=htons(portnumber);  // (将本机器上的short数据转化为网络上的short数据)端口号

    server_addr.sin_addr=*((struct in_addr *)host->h_addr); // IP地址

   

    /* 客户程序发起连接请求 */

    if(connect(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1)

    {

        fprintf(stderr,"Connect Error:%s\a\n",strerror(errno));

        exit(1);

    }

 

    /* 连接成功了 */

    printf("Please input char:\n");

   

    /* 发送数据 */

    fgets(buffer,1024,stdin);

    write(sockfd,buffer,strlen(buffer));

 

    /* 结束通讯 */

    close(sockfd);

    exit(0);

}

 

 

 


http://www.niftyadmin.cn/n/1262353.html

相关文章

javascript最最常用的55个经典技巧

. οncοntextmenu"window.event.returnValuefalse" 将彻底屏蔽鼠标右键<table border οncοntextmenureturn(false)><td>no</table> 可用于Table. <body onselectstart"return false"> 取消选取、防止复制. οnpaste"retur…

15、UDP服务器

基于UDP—服务器 创建一个socket&#xff0c;用函数socket() 绑定IP地址&#xff0c;端口等信息到socket上&#xff0c;用函数bind() 循环接收数据&#xff0c;用函数recvfrom() 关闭网络连接 基于UDP—客户端 创建一个sock…

iWeather需求讨论会议

时间&#xff1a;2012年3月27日 20:00至21:00 参与人&#xff1a;Sara&#xff0c;Henry&#xff0c;Eric&#xff0c;Cathy 会议提出了iWeather的需求、UI以及架构方向。 Henry建议的“图书共享策略”得到了Eric等人的一致赞同。 同时&#xff0c;由于Eric同志请假回家&#x…

16、并发服务器

UDP并发服务器 UDP循环服务器实现的方法&#xff1a; UDP服务器每次从套接字上读取一个客户端的请求&#xff0c;接着处理&#xff0c;然后将结果返回给客户机。 socket(); bind(); while(1) { recvfrom(); process(); sendto(); } TCP循环服务器 TCP循环服务器接受一个客户端的…

UNP Chapter 23 - 线程

23.1. 概述 在传统的UNIX模型中&#xff0c;当一个进程需要由另一个实体执行某件事时&#xff0c;该进程派生(fork)一个子进程&#xff0c;让子进程去进行处理。UNIX下的大多数网络服务器程序都是这么编写的&#xff0c;这在我们的并发服务程序例子中可以看出&#xff1a;父进程…

linux下的framebuffer(1)

概念&#xff1a; 1、像素&#xff1a;pixel,点阵&#xff0c;就是屏幕上的一个点。 2、Bpp:每个像素所占的bit数。bit数越大&#xff0c;一个像素能表现颜色数越多。8bpp&#xff0c;能表现256种颜色。16Bpp能表现65536种颜色。 3、分辨率&#xff1a;一个屏幕x方向和y方向…

PL/SQL函数笔记

-----函数总结: --一,数字函数: --abs(n):用于返回n的绝对值declare v_abs number(6, 2);begin v_abs : abs(&no); dbms_output.put_line(绝对值: || v_abs);end;select abs(-34) from dual; ---exp(n):返回e的n次幂(e2.71828183...).declare v_exp number(6, 2);begin v_e…

linux下的framebuffer(2)

目前根据自己对linux中framebuffer的了解写了如下的代码&#xff1a; 下面是用到的一些文件&#xff0c;在linux下编译通过&#xff0c;显示图形效果。 效果&#xff1a;主要代码在fb.c中&#xff0c;在显卡x,y(1100,100)出显示x0,y0(130,150)大小的颜色&#xff0c;再在x0,y0…