TCP收发——计算机网络——day02

今天主要讲了TCP的收发

TCP发端步骤

①socket
②connect
③send
④close

TCP收端步骤

①socket
②bind
③listen
④accept
⑤recv
⑥clise

其函数主要有

connect

int connect(int sockfd, const struct sockaddr *addr,
                   socklen_t addrlen);
  功能:
    发送链接请求
  参数:
    sockfd:套接字文件描述符
    addr:目的地址存放空间首地址
    addrlen:IP地址的大小
  返回值:
    成功返回0
    失败返回-1

send

ssize_t send(int sockfd, const void *buf, size_t len, int flags);
  功能:
    发送数据
  参数:
    sockfd:文件描述符
    buf:发送数据空间首地址
    len:发送数据的长度
    flags:属性默认为0 
  返回值:
    成功返回实际发送字节数
    失败返回-1

recv

ssize_t recv(int sockfd, void *buf, size_t len, int flags);
  功能:
    接收数据 
  参数:
    sockfd:套接字文件描述符 
    buf:存放数据空间首地址
    len:最大接收数据的长度
    flags:属性默认为0 
  返回值:
    成功返回实际接收字节数
    失败返回-1 
    如果对方退出,返回0 

listen

int listen(int sockfd, int backlog);
  功能:
    监听客户端发送的连接请求
    该函数不会阻塞
  参数:
    sockfd:套接字文件描述符
    backlog:允许等待的尚未被处理的三次握手请求的最大个数
  返回值:
    成功返回0 
    失败返回-1 

accept

int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  功能:
    处理等待连接队列中的第一个连接请求
    该函数具有阻塞功能(如果没有人发送链接请求,会阻塞等待)
  参数:
    socket:套接字文件描述符
    address:存放IP地址的空间首地址
    addrlen:存放IP地址大小空间首地址
  返回值:
    成功返回一个新的文件描述符
    失败返回-1 

eg:利用TCP实现跨主机的文件发送

send端

#include"head.h"

int main(void)
{
	int sockfd = 0;
	FILE *fp = 0;
	int ret = 0;
	ssize_t nsize = 0;
	ssize_t nret = 0;
	char tmpbuff[4096] = {0};
	struct sockaddr_in srcaddr;
	char filename[256] = {"a.txt"};

	gets(filename);
	
	srcaddr.sin_family = AF_INET;
	srcaddr.sin_port = htons(50000);
	srcaddr.sin_addr.s_addr = inet_addr("192.168.1.152");

	sockfd = socket(AF_INET,SOCK_STREAM,0);
	if(-1 == sockfd)
	{
		perror("fail to socket");
		return -1;
	}

	ret = connect(sockfd,(struct sockaddr *)&srcaddr,sizeof(srcaddr));
	if(-1 == ret)
	{
		perror("fail to connect");
		return -1;
	}

	nsize = send(sockfd,filename,strlen(filename),0);
	if(-1 == nsize)
	{
		perror("fail to send");
		return -1;
	}

    fp = fopen(filename, "rb");
    if (fp == NULL) 
	{
        perror("fail to fopen");
        return -1;
	}


    while(1)
	{
		memset(tmpbuff,0,sizeof(tmpbuff));
		sleep(1);
		nsize = fread(tmpbuff, sizeof(char), 4096, fp);
		if(0 >= nsize)
		{
			break;
		}
			
        send(sockfd, tmpbuff,nsize, 0);
    }

	close(sockfd);
	fclose(fp);
	return 0;
}

recv端

#include"head.h"

int main(void)
{
	FILE *file = NULL;
	ssize_t nsize = 0;
	ssize_t nret = 0;
	char name[20] = {0};
	char tmpbuff[4096] = {0};
	int sockfd = 0;
	int recfd = 0;
	int ret = 0;
	struct sockaddr_in recaddr;


	recaddr.sin_family = AF_INET;
	recaddr.sin_port = htons(50000);
	recaddr.sin_addr.s_addr = INADDR_ANY;

	sockfd = socket(AF_INET,SOCK_STREAM,0);
	if(-1 == sockfd)
	{
		perror("fail to socket");
		return -1;
	}

	ret = bind(sockfd,(struct sockaddr *)&recaddr,sizeof(recaddr));
	if(-1 == ret)
	{
		perror("fail to bind");
		return -1;
	}

	ret = listen(sockfd,10);
	if(-1 == ret)
	{
		perror("fail to listen");
		return -1;
	}

	recfd = accept(sockfd,NULL,NULL);
	if(-1 == recfd)
	{
		perror("fail to accept");
		return -1;
	}

	nret = recv(recfd,name,sizeof(name),0);
	if(-1 == nret)
	{
		perror("fail to recv");
		return -1;
	}

	file = fopen(name,"wb");

	 while ((nsize = recv(recfd, tmpbuff, sizeof(tmpbuff), 0)) > 0)
    {
        if (fwrite(tmpbuff, sizeof(char), nsize, file) < nsize)
        {
            perror("fail to write file");
            fclose(file);
            close(recfd);
            close(sockfd);
            return -1;
        }
    }

	close(recfd);
	fclose(file);
	close(sockfd);

	return 0;
}

结果:
在这里插入图片描述
以上就是今天内容!

  • 18
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值