作者a942195 (Truth)
看板LinuxDev
标题[问题] wget 下载
时间Mon Nov 10 23:09:04 2014
最近在版子上要从server端下载更新档来更新
int download_file(char *img[][2],int count){
char cmd[128] = {0};
int i;
//strcat(cmd,"wget -O /data/update.xml'");
for( i=0;i<count;i++){
strcat(cmd,"wget ");
strcat(cmd,"-O /Data/");
strcat(cmd,img[i][0]);
strcat(cmd," ");
strcat(cmd,"\"");
strcat(cmd,url);
strcat(cmd,"?");
strcat(cmd,"&img_name=");
strcat(cmd,img[i][0]);
strcat(cmd,"&token=");
strcat(cmd,token_decrypt);
strcat(cmd,"\"");
system(cmd)
memset(cmd,0,sizeof(cmd));
}
但是发现到下载到的档案跟原本的档案大小差很多 而且还会出现segmentation fault
不知道这样的写法对不对 想说会不会是同步下载的关系 难道不能等一个下载玩
在接下一个吗?
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 220.135.170.126
※ 文章网址: http://webptt.com/cn.aspx?n=bbs/LinuxDev/M.1415632147.A.766.html
1F:推 filiaslayers: 你怎麽不用script来做? 11/10 23:10
2F:推 cutekid: 要不要把 cmd printf 出来看一下 11/11 11:36
3F:→ lantw44: 有没有可能 128 不够大? 11/11 21:03
4F:→ qsort: char *img[][2]有点怪,img ia a array pointers to char[2] 11/12 08:47
5F:→ qsort: 所以你每个image name最多就两个char, 扣掉\0, 剩一个char 11/12 08:47
6F:→ qsort: 请问你的档名是"a"这类的吗? 11/12 08:48
7F:→ qsort: 再来是,请不要用strcat, 那是下流的写法 11/12 08:49
8F:→ qsort: int len=0; //reset buff to head 11/12 08:55
9F:→ qsort: len+=snprintf(buff+len,sizeof(buff)-len,format,...); 11/12 08:56
10F:→ qsort: 建议把snprintf学起来,strcat真的不要再用了。 11/12 08:57
11F:→ qsort: 嗯, 总结: 请爱用script. 11/12 08:58
12F:推 dirkc: 原po的char *img[][2]部份应该无错,img[][]是char * 11/12 11:28
13F:推 qsort: @dirkc: 你说的对﹐是我误会成"char img[][2]", 但我还是觉 11/12 13:01
14F:→ qsort: 得有可能原po误用了,一般人不会用到这麽复杂的(char*)[][] 11/12 13:02
15F:→ a942195: 感谢楼上大大的回复 我在试看看 我也觉得strcat 很蠢 所 11/12 19:33
16F:→ a942195: 所以也有想到用snprintf 11/12 19:34
17F:嘘 s942816: 学生?文组 08/13 00:31