http客户端如何写
使用wireshark协助,设置网卡本地,设置过滤器:http && (ip.src == 192.168.1.80 && ip.dst == 192.168.1.81) || (ip.src == 192.168.1.81 && ip.dst == 192.168.1.80)。
查看数据:
时间
有限搬代码:
int Get_File(int sockfd,char *url,int filelength,char *filebuf)
{
int count;
char range[32];
int i;
int ret = 0;
char *p = NULL;
int downOver=0;
int downlength=0,writeRet;
int p_file;
int s32TimeOut=5*1000;
fd_set rfds;
int nRecvBuf=64*1024;//设置为32K
struct timeval tv; count = (filelength%MAX_RECV_SIZE)?(filelength/MAX_RECV_SIZE +1):(filelength/MAX_RECV_SIZE); for(i=0;i<1;i++)
{
if((i == (count-1))&&(filelength%MAX_RECV_SIZE))
sprintf(range,"%d-%d",i*MAX_RECV_SIZE,filelength-1);
else
sprintf(range,"%d-%d",i*MAX_RECV_SIZE,(i+1)*MAX_RECV_SIZE-1); Package_Url_Get_File(url,range);
printf("send = %s \n",g_buf_send); Send(sockfd, g_buf_send, strlen(g_buf_send), 0);
Net_Http_GetResponseHeader(sockfd);
/*需改为提取http 返回协议头和协议体总长,然后定长接收*/
//setsockopt(sockfd,SOL_SOCKET,SO_RCVTIMEO,(char*)s32TimeOut,sizeof(s32TimeOut));
//setsockopt(sockfd,SOL_SOCKET,SO_RCVBUF,(char*)nRecvBuf,sizeof(nRecvBuf));
while(!downOver)
{
re_recv:
tv.tv_sec = 5;
tv.tv_usec = 0;
FD_ZERO(&rfds); //每次循环都要清空集合,否则不能检测描述符变化
FD_SET(sockfd, &rfds); //添加描述符
memset(g_buf_recv,0x0,sizeof(g_buf_recv));
switch (select(sockfd + 1, &rfds, NULL, NULL, &tv))
{
case 1:
{
usleep(100);
ret = Recv(sockfd,g_buf_recv,sizeof(g_buf_recv)-1,0);
s32TimeOut = 0;
printf("recv len = %d\n", ret);
if ( 0 > ret )
{
printf("recvfrom error\n");
break;
}
p=g_buf_recv;
Write_File(p,"",ret);
printf("strlen(p)=%d \n",strlen(p));
if(ret > 0) downlength += ret;
if(downlength >= filelength) downOver = 1;
goto re_recv; }
case 0:
{
printf("timeout\n");//再次轮询 s32TimeOut--;
if (s32TimeOut == 0)
{
printf("last timeout\n");
}
break;
}
default:
printf("Failed to select\n");//select错误,退出程序
} }
}
return 0;
}
void Package_Url_Get_File(char *url, char *range)
{
char buf_range[64];
memset(g_buf_send,0x0,sizeof(g_buf_send));
sprintf(g_buf_send, "GET %s",url); //HTTP/1.1\r\n 前面需要一个空格
strcat(g_buf_send," HTTP/1.1\r\n");
strcat(g_buf_send, "Host: ");
strcat(g_buf_send, IP);
strcat(g_buf_send, ":");
strcat(g_buf_send, PORT); // sprintf(buf_range, "\r\nRange: bytes=%s\r\n",range);
// strcat(g_buf_send,buf_range);
strcat(g_buf_send,"\r\nConnection: Keep-Alive\r\n\r\n"); }
int Send(int sockfd, char *sendbuf, int len, int flags)
{
int sendlen = 0;
int ret = -1; while(sendlen < len)
{
ret = send(sockfd, sendbuf+sendlen, len-sendlen, flags);
if(-1 == ret)
{
perror("send");
exit(EXIT_FAILURE);
}
else
sendlen += ret; } return 0; }
int Recv(int sockfd, char *recvbuf, int len, int flags)
{
int recv_len; if ((recv_len = recv(sockfd, recvbuf, len, flags)) < 0)
{
perror("recv error");
exit(EXIT_FAILURE);
} return recv_len;
}
char* Net_Http_GetResponseHeader(int sockfd)
{
char c = 0;
int nIndex = 0;
static char ResponseHeader[1024]={0};
int bEndResponse = 0;
while(!bEndResponse && nIndex < 1024)
{
recv(sockfd,&c,1,0);
ResponseHeader[nIndex++] = c;
if(nIndex >= 4)
{
if(ResponseHeader[0]!='H'&&ResponseHeader[1]!='T'
&&ResponseHeader[2]!='T'&&ResponseHeader[3]!='P')
{
printf("ResponseHeader error !\n");
return NULL;
}
if(ResponseHeader[nIndex - 4] == '\r' && ResponseHeader[nIndex - 3] == '\n'
&& ResponseHeader[nIndex - 2] == '\r' && ResponseHeader[nIndex - 1] == '\n')
bEndResponse = 1;
}
}
ResponseHeader[nIndex]=0;
printf("ResponseHeader:%s \n",ResponseHeader);
return ResponseHeader; }
假如要实现断点则只需要加入字段Range: bytes=%d- (%d)是你需要开始下载的文件的起始字节数。
1.在linux 在写代码过程中要注意写入文件时候,写入的字节数要是recv函数返回的值为准,不要使用strlen函数,在返回的包中,尽量先将包头过滤出来。
2.在window下,打开文件函数fopen需要指定wb二进制方式打开,否则在windows下,fwrite函数写入数据时会加上回车符OX0D。
3.在window下,调试时候,如果在调用fwrite函数写入,没有经过fclose,ctrl+c程序终止的话会造成最后一段数据没有真正写入到文件。
http客户端如何写的更多相关文章
- inno安装客户端,写注册表url调用客户端
[Registry] Root: HKCR; SubKey: xxx; ValueData: "xxx"; ValueType: string; Flags: CreateValu ...
- Hadoop源码分析之客户端向HDFS写数据
转自:http://www.tuicool.com/articles/neUrmu 在上一篇博文中分析了客户端从HDFS读取数据的过程,下面来看看客户端是怎么样向HDFS写数据的,下面的代码将本地文件 ...
- Ubuntu15.10下华南师大锐捷认证客户端的使用详解
本文测试Linux系统环境为Ubuntu15.10 Destop,暂未在其他系统下验证过,不代表LTS版本或较旧的版本按照本文所述方法可以100%正确使用最新的锐捷认证客户端. 本文面向对象为华南师范 ...
- Socket编程——客户端,服务器端的读写操作
URL网络编程,最大的特征就是一对一的响应! 1:客户端“写”,服务器端用于“读” package coreBookSocket2; import java.io.InputStreamReader; ...
- Hbase客户端API基础小结笔记(未完)
客户端API:基础 HBase的主要客户端接口是由org.apache.hadoop.hbase.client包中的HTable类提供的,通过这个类,用户可以完成向HBase存储和检索数据,以及删除无 ...
- MQTT客户端与服务代理的案列
服务端,采用 Mosquitto 来转发分发消息. 客户端自己写. 服务端 启动 mosquitto (底下的命令是我自己放到环境变量里面的,通过alias 运行mosquitto) Ishallbe ...
- Hbase写数据,存数据,读数据的详细过程
Client写入 -> 存入MemStore,一直到MemStore满 -> Flush成一个StoreFile,直至增长到一定阈值 -> 出发Compact合并操作 -> 多 ...
- TortoiseSVN是windows平台下Subversion的免费开源客户端。
一般我们都是先讲讲服务器的配置,然后再讲客户端的使用,但是在TortoiseSVN上,却可以反过来.因为,如果你的要求不高,只是想在本机,或者是可信任的局域网络中使用SVN版本控制,可以不需要安装SV ...
- Eclipse rap 富客户端开发总结(9) : rap上传与下载
一 上传 上传即将文件上传到服务器上,在客户端需要写相应的脚本,服务器端需要注册相应的 handle 接受客户端的请求. 原理: Rap 的上传和下载是通过普通的 web 的方式进行上传和下载的 , ...
随机推荐
- Golang 热编译rizla 插件
今天在写gin接口的时候,每次添加或修改个接口都需要重启项目才能测试,感觉很麻烦. 因为beego有bee工具,bee run启动项目fsnotify会监控文件变动,经查发现在iris项目中有个插件支 ...
- Django路由层与视图层
表与表之间建关系 图书管理系统为例 书籍表 出版社表 作者表 三个表之间的关系: 考虑表之间的关系:换位思考 1.书籍和出版社是一对多,外键字段建立在书籍表中 2.书籍和作者是多对多, 需要建立第三方 ...
- 关于前端Dom的总结
简介 DOM (Document Object Model) 文档对象模型 DOM思想使用节点树(node tree)的概念来描述一个HTML页面,页面中的每一个元素.属性.文本都被认为是节点.此外, ...
- 黑科技如何制造人类V2.0?
黑科技泛指人类尚未成熟但具有巨大潜力的科学技术,智能手机.大数据.扫码支付.电子地图等等都曾属于黑科技范畴,随着时间的推移,它们慢慢成熟,且展现出巨大的能力,影响人类进程,最终黑科技转变成人类伟大的创 ...
- Springboot中RestTemplate -- 用更优雅的方式发HTTP请求
RestTemplate是Spring提供的用于访问Rest服务的客户端,RestTemplate提供了多种便捷访问远程Http服务的方法,能够大大提高客户端的编写效率. 我之前的HTTP开发是用ap ...
- CentOS下图形界面安装_Orcaale 11g
1.安装说明 使用到的工具: 软件名称 版本 软件包 系统 centOS6.8 CentOS-6.8-x86_64-bin-DVD1.iso 数据库 ORACLE11g linux.x64_11gR2 ...
- 吴裕雄--天生自然C语言开发:enum(枚举)
enum DAY { MON=, TUE, WED, THU, FRI, SAT, SUN }; enum DAY { MON=, TUE, WED, THU, FRI, SAT, SUN }; en ...
- window 彻底删除mysql
1. 运行regedit.exe,找到HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\MySQL 文件夹,将其删除: 2. 找到HKEY_LOCAL_ ...
- AppCompatActivity 透明背景
<!-- 背景透明样式 --> <style name="AppTheme.transparent" parent="Theme.AppCompat.L ...
- linux上部署jenkins
http://www.pianshen.com/article/1133171043/相关jenkins链接 下载jenkins的war包:https://blog.csdn.net/Aaron_Zh ...