博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用socket下载文件(C++)
阅读量:4071 次
发布时间:2019-05-25

本文共 2655 字,大约阅读时间需要 8 分钟。

刚学习socket编程,写了一个下载文件的小程序,写的不好大家不要吐槽。

客户端:

 

#include
#include
#include
#include
#include
#include
#include
#define BUFF_SIZE 100int main(int argv,char *args[]){ int servsock; struct sockaddr_in servaddr; if(argv!=3){ printf("Usage:%s
",args[0]); exit(1); } servsock = socket(PF_INET,SOCK_STREAM,0); if(servsock == -1) { printf("socket() error\n"); exit(1); } memset(&servaddr,0,sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_addr.s_addr = inet_addr(args[1]); servaddr.sin_port = htons(atoi(args[2])); if(connect(servsock,(struct sockaddr*)&servaddr,sizeof(servaddr)) ==-1) { printf("connect() error\n"); exit(1); }else{ printf("connected.....\n"); } printf("please input filename:"); char filename[BUFF_SIZE]; memset(filename,0,sizeof(char)*BUFF_SIZE); scanf("%s",filename); write(servsock,filename,strlen(filename)); int successFlag; read(servsock,&successFlag,sizeof(successFlag)); if(successFlag!=1){ printf("input file is not existed!\n successFlag is %d\n",successFlag); exit(1); }else{ FILE *fp = fopen(filename,"w"); while(1){ memset(filename,0,BUFF_SIZE); int revlen = read(servsock,filename,BUFF_SIZE); if(revlen ==0) break; fputs(filename,fp); } fclose(fp); printf("complete!\n"); } close(servsock); return 0;}

服务器:

 

 

#include
#include
#include
#include
#include
#include
#include
#define BUFF_SIZE 100int main(int argv,char *args[]){ int servsock,clntsock; struct sockaddr_in servaddr,clntaddr; if(argv!=2){ printf("Usage:%s
",args[0]); exit(1); } servsock = socket(PF_INET,SOCK_STREAM,0); memset(&servaddr,0,sizeof(servaddr)); servaddr.sin_family = AF_INET; servaddr.sin_addr.s_addr = htonl(INADDR_ANY); servaddr.sin_port = htons(atoi(args[1])); if(bind(servsock,(struct sockaddr*)&servaddr,sizeof(servaddr)) ==-1) { printf("bind() error\n"); exit(1); } if(listen(servsock,5) ==-1) { printf("listen() error\n"); exit(1); } socklen_t len = sizeof(clntaddr); clntsock = accept(servsock,(struct sockaddr*)&clntaddr,&len); char filename[BUFF_SIZE]; int msglen=read(clntsock,filename,BUFF_SIZE); filename[msglen]=0; printf("receiver filename is: %s\n",filename); FILE *fp = fopen(filename,"r"); int successFlag = 0; if(fp) successFlag = 1; write(clntsock,&successFlag,sizeof(successFlag)); if(fp == NULL){ printf("NULL\n"); close(clntsock); close(servsock); return 0; } while(fgets(filename,BUFF_SIZE,fp)!=NULL){ int ll = strlen(filename); printf("length:%d content:%s",ll,filename); write(clntsock,filename,strlen(filename)); } fclose(fp); close(clntsock); close(servsock); return 0;}

 

 

 

 

 

转载地址:http://oehji.baihongyu.com/

你可能感兴趣的文章
《软件体系结构》 练习题
查看>>
《数据库系统概论》 第一章 绪论
查看>>
《数据库系统概论》 第二章 关系数据库
查看>>
《数据库系统概论》 第三章 关系数据库标准语言SQL
查看>>
SQL语句(二)查询语句
查看>>
SQL语句(六) 自主存取控制
查看>>
《计算机网络》第五章 运输层 ——TCP和UDP 可靠传输原理 TCP流量控制 拥塞控制 连接管理
查看>>
堆排序完整版,含注释
查看>>
二叉树深度优先遍历和广度优先遍历
查看>>
生产者消费者模型,循环队列实现
查看>>
PostgreSQL代码分析,查询优化部分,process_duplicate_ors
查看>>
PostgreSQL代码分析,查询优化部分,canonicalize_qual
查看>>
PostgreSQL代码分析,查询优化部分,pull_ands()和pull_ors()
查看>>
ORACLE权限管理调研笔记
查看>>
移进规约冲突一例
查看>>
IA32时钟周期的一些内容
查看>>
SM2椭圆曲线公钥密码算法
查看>>
获得github工程中的一个文件夹的方法
查看>>
《PostgreSQL技术内幕:查询优化深度探索》养成记
查看>>
PostgreSQL查询优化器详解之逻辑优化篇
查看>>