c语言实现 windows socket_C语言实现Socket简单通信

c语言实现 windows socket_C语言实现Socket简单通信

点击上方“学士科技”,选择“设为星标”

资讯、技术干货第一时间送达!

3500dbc6067b10327fe47cfe4894ff97.gif

C语言基础合集,点我点我~~~

C语言进阶合集,点我点我~~~

C语言高级:

01.C语言实现字符串的加密和解密

02.C语言数据结构——链表

03.C语言——文件的基本操作

04.C语言——【数据结构】图的存储结构之邻接表

服务端

/************************************************************************************************************************1、int socket(int family,int type,int protocol)family:    指定使用的协议簇:AF_INET(IPv4) AF_INET6(IPv6) AF_LOCAL(UNIX协议) AF_ROUTE(路由套接字) AF_KEY(秘钥套接字)type:    指定使用的套接字的类型:SOCK_STREAM(字节流套接字) SOCK_DGRAMprotocol:    如果套接字类型不是原始套接字,那么这个参数就为02、int bind(int sockfd, struct sockaddr *myaddr, int addrlen)sockfd:    socket函数返回的套接字描述符myaddr:    是指向本地IP地址的结构体指针myaddrlen:    结构长度struct sockaddr{    unsigned short sa_family; //通信协议类型族AF_xx    char sa_data[14];  //14字节协议地址,包含该socket的IP地址和端口号};struct sockaddr_in{    short int sin_family; //通信协议类型族    unsigned short int sin_port; //端口号    struct in_addr sin_addr; //IP地址    unsigned char si_zero[8];  //填充0以保持与sockaddr结构的长度相同};3、int connect(int sockfd,const struct sockaddr *serv_addr,socklen_t addrlen)sockfd:    socket函数返回套接字描述符serv_addr:    服务器IP地址结构指针addrlen:    结构体指针的长度4、int listen(int sockfd, int backlog)sockfd:    socket函数绑定bind后套接字描述符backlog:    设置可连接客户端的最大连接个数,当有多个客户端向服务器请求时,收到此值的影响。默认值205、int accept(int sockfd,struct sockaddr *cliaddr,socklen_t *addrlen)sockfd:    socket函数经过listen后套接字描述符cliaddr:    客户端套接字接口地址结构addrlen:    客户端地址结构长度6、int send(int sockfd, const void *msg,int len,int flags)7、int recv(int sockfd, void *buf,int len,unsigned int flags)sockfd:    socket函数的套接字描述符msg:    发送数据的指针buf:    存放接收数据的缓冲区len:    数据的长度,把flags设置为0*************************************************************************************************************************/

读函数read

ssize_t read(int fd,void *buf,size_t nbyte)

read函数是负责从fd中读取内容.成功时,read返回实际所读的字节数,如果返回的值是0,表示已经读到文件的结束了.

小于0表示出现了错误.如果错误为EINTR说明读是由中断引起的, 如果是ECONNREST表示网络连接出了问题.参数nbyte是请求读取的字节数,读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移。注意这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写位置是记在内核中的

写函数write

ssize_t write(int fd,const void *buf,size_t nbytes)

write函数将buf中的nbytes字节内容写入文件描述符fd.成功时返回写的字节数.失败时返回-1. 并设置errno变量. 在网络程序中,当我们向套接字文件描述符写时有俩种可能. 1)write的返回值大于0,表示写了部分或者是全部的数据. 2)返回的值小于0,此时出现了错误.我们要根据错误类型来处理. 如果错误为EINTR表示在写的时候出现了中断错误. 如果为EPIPE表示网络连接出现了问题(对方已经关闭了连接).

#include#include#include#include#include#include#include#include#define PORT 1500//端口号#define BACKLOG 5/*最大监听数*/ int main(){    int sockfd,new_fd;/*socket句柄和建立连接后的句柄*/    struct sockaddr_in my_addr;/*本方地址信息结构体,下面有具体的属性赋值*/    struct sockaddr_in their_addr;/*对方地址信息*/    int sin_size;    sockfd=socket(AF_INET,SOCK_STREAM,0);//建立socket    if(sockfd==-1){        printf("socket failed:%d",errno);        return -1;    }    my_addr.sin_family=AF_INET;/*该属性表示接收本机或其他机器传输*/    my_addr.sin_port=htons(PORT);/*端口号*/    my_addr.sin_addr.s_addr=htonl(INADDR_ANY);/*IP,括号内容表示本机IP*/    bzero(&(my_addr.sin_zero),8);/*将其他属性置0*/    if(bind(sockfd,(struct sockaddr*)&my_addr,sizeof(struct sockaddr))<0){//绑定地址结构体和socket        printf("bind error");        return -1;    }        listen(sockfd,BACKLOG);//开启监听 ,第二个参数是最大监听数        while(1){            sin_size=sizeof(struct sockaddr_in);            new_fd=accept(sockfd,(struct sockaddr*)&their_addr,&sin_size);//在这里阻塞知道接收到消息,参数分别是socket句柄,接收到的地址信息以及大小            if(new_fd==-1){                printf("receive failed");        } else{            printf("receive success");            send(new_fd,"Hello World!",12,0);//发送内容,参数分别是连接句柄,内容,大小,其他信息(设为0即可)        }    }    return 0;}

客户端

#include#include#include#include#include#include#include#include #define DEST_PORT 1500//目标地址端口号#define DEST_IP "127.0.0.1"/*目标地址IP,这里设为本机*/ #define MAX_DATA 100//接收到的数据最大程度int main(){    int sockfd,new_fd;/*cocket句柄和接受到连接后的句柄 */    struct sockaddr_in dest_addr;/*目标地址信息*/    char buf[MAX_DATA];//储存接收数据    sockfd=socket(AF_INET,SOCK_STREAM,0);/*建立socket*/    if(sockfd==-1){        printf("socket failed:%d",errno);    }    //参数意义见上面服务器端    dest_addr.sin_family=AF_INET;     dest_addr.sin_port=htons(DEST_PORT);    dest_addr.sin_addr.s_addr=inet_addr(DEST_IP);    bzero(&(dest_addr.sin_zero),8);        if(connect(sockfd,(struct sockaddr*)&dest_addr,sizeof(struct sockaddr))==-1){//连接方法,传入句柄,目标地址和大小        printf("connect failed:%d",errno);//失败时可以打印errno    } else{        printf("connect success");        recv(sockfd,buf,MAX_DATA,0);//将接收数据打入buf,参数分别是句柄,储存处,最大长度,其他信息(设为0即可)。        printf("Received:%s",buf);    }    close(sockfd);//关闭socket    return 0;} 
85b9d7e9025efd28d2a45a76a8886891.gif

END

79568011f0ca7bac47cfa164f4633d5c.png
e31028839dbd1d501ba13c6f30fb2a84.gif