当前位置:  技术问答>linux和unix

socket文件传输-linux服务端,window客户端

    来源: 互联网  发布时间:2016-10-02

    本文导语:  小弟写了一个socket程序:服务端是linux,客户端是window。实现的功能是客户端向服务器发送文件,服务器接受文件后进行处理再发送给客户端。服务器是多线程的,即当有新的socket连接就开启一个新线程 有多个(例...

小弟写了一个socket程序:服务端是linux,客户端是window。实现的功能是客户端向服务器发送文件,服务器接受文件后进行处理再发送给客户端。服务器是多线程的,即当有新的socket连接就开启一个新线程
有多个(例如30个)客户端同时向服务器发送文件,服务器接受后文件都是正确的。可当服务器处理了这些文件后发送给客户端时,有些客户端接收到完整的文件,有些则接受失败,出现10060错误。

疑问:1.客户端在等待服务器发送文件的时候,会不会因为时间太长导致这个连接出现问题。
这个要怎么解决啊?小弟想用异步方式去解决,但具体怎么实现不知道啊?异步方式是通过函数参数去控制一下就可以实现了吗?
哪位大侠可以给个实例参考一下

2.下面是部分代码: 哪位大侠何以看一下这是阻塞方式还是非阻塞方式?
服务端发送文件部分代码
 memcpy(sendfile,Attri->name,1020);

if(stat(sendfile,&statbuf)==-1)
    {
fprintf(stderr,"Err:Get stat on %s Error:%sn",sendfile,strerror(errno));
printf("%d***Err:Get stat on %s Error:%sn",nums,sendfile);
goto Error2;
    } 

if(S_ISDIR(statbuf.st_mode))
  {
printf("Err: This is directory!n");
goto Error2;
}
if(S_ISREG(statbuf.st_mode))
printf("%d %s File size:%ld bytesn",nums,sendfile,statbuf.st_size);  
        
if(statbuf.st_size != Attri->size)
{
printf("Err: Create %s failed!n",sendfile);
goto Error2;
}

strcpy(buffer,"signed_");
strcat(buffer, sendfile);
strcpy(attri2->name,buffer);
bzero(buffer,BUFLEN);
      attri2->size = statbuf.st_size;

md5_process(attri2->name,attri2->md5);
attri2->md5[16] = '';

        memcpy(buffer,(char *)attri2,1024);
if(-1==send(new_server_socket,buffer,BUFLEN,0))
{
printf("send failed:n");
printf(" Error:%sn",strerror(errno));
goto Error2;
}
        bzero(buffer,BUFLEN); 

bytes_read=-2;
printf("Create send file %s:n",sendfile);
        if((to_fd = open(sendfile,O_RDONLY))==-1)
{
printf("%d***send client:open %s failed!n",nums,sendfile);
goto Error2;
//exit(1);
}
inte = attri2->size/1024;
residual = attri2->size%1024;    
        if(residual>0) inte +=1;
k=0;
printf("%d Send signed file %s: size=%dn",nums,sendfile,attri2->size);
        tchl=0;
for(k=0;kname);
goto Error1;
}
     else if(bytes_read>0)
         {
if(-1==send(new_server_socket,buffer,bytes_read,0))
{
printf("Err: send failed; k=%d Get stat on %s Error:%sn",k,sendfile,strerror(errno));
goto Error1;
}
bzero(buffer,BUFLEN);

                        tchl += bytes_read;
    }
}
printf("%d  Send signed file %s ok  size:%d n",n


客户端接收文件部分代码
#ifdef RECE
    //begin receive file from sign server!
printf("************ begin receive file from sign server! ************n");
//length = recv(client_socket,buffer,BUFFER_SIZE,0);
nRecv=0;
while(nRecv!=sizeof(buffer))
{
length = recv(client_socket,buffer+nRecv,1024-nRecv,0); 
if(length == SOCKET_ERROR || length == 0)
{
id = WSAGetLastError();
switch (id)
{
case WSANOTINITIALISED: printf("Err:not initializedn"); break;
case WSASYSNOTREADY: printf("Err:sub sys not readyn"); break;
case WSAHOST_NOT_FOUND: printf("Err:name server not foundn");  break;
case WSATRY_AGAIN:  printf("Err:server failn");  break;
case WSANO_RECOVERY:  printf("Err:no recoveryn");   break;
case WSAEINPROGRESS:  printf("Err:socket blocked by other progn"); break;
case WSANO_DATA:   printf("Err:no data recordn");  break;
case WSAEINTR:   printf("Err:blocking call canciledn");  break;
case WSAEPROCLIM: printf("Err:limit exceededn");break;
case WSAEFAULT:  printf("Err:lpWSAData in startup not validn");break;
default: printf("Err:unknown error id = %dn",id); break;
};
printf("Err: Receive first info from server failed!n");
free(Attri2);
closesocket(client_socket);
WSACleanup();
return NULL;
}
nRecv +=length;
printf("Info:nRecv=%d  ",nRecv);
}

memcpy((char*)Attri2,buffer,1024);
printf("%d File name: %sn",nums,Attri2->name);
    printf("%d File size: %ld bytesn",nums,Attri2->size);
memset(buffer,0,BUFFER_SIZE);

    printf("%d Create file %s!n",nums,Attri2->name);
    if((to_fd=fopen(Attri2->name,"wb+"))==NULL)
    {
fprintf(stderr,"Open %s Error:%sn",Attri2->name,strerror(errno));
printf("Err: %d Open %s Error:%sn",nums,Attri2->name);
free(Attri2);
closesocket(client_socket);
WSACleanup();
return NULL;
}
inte=0;
residual=0;
inte = Attri2->size/1024;
residual = Attri2->size%1024;
k=0;
tems =0;
if(residual>0) inte +=1;
    bytes_read=0;
tems = Attri2->size;
printf("Begin to receive file from server!n");
for(k=0;k=1024)
{
while(nRecv!=sizeof(buffer))
{
length = recv(client_socket,buffer+nRecv,1024-nRecv,0); 
if(length == SOCKET_ERROR || length == 0)
{
id = WSAGetLastError();
switch (id)
{
case WSANOTINITIALISED: printf("Err:not initializedn"); break;
case WSASYSNOTREADY: printf("Err:sub sys not readyn"); break;
case WSAHOST_NOT_FOUND: printf("Err:name server not foundn");  break;
case WSATRY_AGAIN:  printf("Err:server failn");  break;
case WSANO_RECOVERY:  printf("Err:no recoveryn");   break;
case WSAEINPROGRESS:  printf("Err:socket blocked by other progn"); break;
case WSANO_DATA:   printf("Err:no data recordn");  break;
case WSAEINTR:   printf("Err:blocking call canciledn");  break;
case WSAEPROCLIM: printf("Err:limit exceededn");
case WSAEFAULT:  printf("Err:lpWSAData in startup not validn");
default: printf("Err:unknown error id = %dn",id); break;
};
printf("Err: filename:%s 1024receive error.\n",Attri2->name);
fclose(to_fd);
free(Attri2);
closesocket(client_socket);
WSACleanup();
return NULL;
}
nRecv +=length;
}
notsame =0;
bytes_read = BUFFER_SIZE;
            tems -=1024;
fwrite(buffer,bytes_read,1,to_fd);
}
else
{
while(nRecv!=residual)
{
length = recv(client_socket,buffer+nRecv,residual-nRecv,0); 
if(length == SOCKET_ERROR || length == 0)
{
id = WSAGetLastError();
switch (id)
{
case WSANOTINITIALISED: printf("not initializedn"); break;
case WSASYSNOTREADY: printf("sub sys not readyn"); break;
case WSAHOST_NOT_FOUND: printf("name server not foundn");  break;
case WSATRY_AGAIN:  printf("server failn");  break;
case WSANO_RECOVERY:  printf("no recoveryn");   break;
case WSAEINPROGRESS:  printf("socket blocked by other progn"); break;
case WSANO_DATA:   printf("no data recordn");  break;
case WSAEINTR:   printf("blocking call canciledn");  break;
case WSAEPROCLIM: printf("limit exceededn");
case WSAEFAULT:  printf("lpWSAData in startup not validn");
default: printf("unknown error id = %dn",id); break;
};
printf("Err: file name:%s length %d rest receive error.n",Attri2->name,length);
fclose(to_fd);
free(Attri2);
closesocket(client_socket);
WSACleanup();
return NULL;
}
nRecv +=length;
}
bytes_read = residual;
int oo = fwrite(buffer,bytes_read,1,to_fd);
printf(" rec tems:%dn",tems);
}
memset(buffer,0,BUFFER_SIZE); 
}
fclose(to_fd);

md5_process(Attri2->name,md5check);
md5check[16] = '';
if(strcmp(md5check,Attri2->md5)!=0)
{
printf("Err: Receive file %s failed!n",Attri2->md5);
remove(Attri2->name);
}
else
{
printf("Info: Receivefile %s successfully!n",Attri2->name);
}

|
“length = recv(client_socket,buffer+nRecv,1024-nRecv,0);  
if(length == SOCKET_ERROR || length == 0)”
length == 0不是错误吧,是因为服务器关闭了连接。

|
可能是中断,查看errno看看是否是EINTR

|
把程序格式弄好一点儿,看着好别扭啊。

|
程序没注释又不整齐。。。

|
唉,手机翻看你的程序更累

    
 
 

您可能感兴趣的文章:

  • php实现socket实现客户端和服务端数据通信源代码
  • socket客户端程序的问题
  • andriod下java socket网络编程:java socket客户端服务端代码示例
  • 客户端 socket 断开后 服务器端系统如何处理?
  • Linux c socket编程:简单的客户端(client)和服务端(server)实现
  • 已和客户端连接建立的socket在客户端CTRL-C后怎么在服务器端捕捉这个错误?
  • 服务器与客户端建立socket连接,如何获得端口号.谢谢
  • python实现socket客户端和服务端简单示例
  • 客户端是linux通过socket编程实现服务器端win平台接收?
  • linux客户端程序能否和windows端的服务器程序进行socket通信?
  • socket编程中客户端绑定端口的问题,请兄弟们指点一下
  • 请问关于socket客户端因事件启动新线程的问题.高手请进
  • socket编程,设为非阻塞,客户端怎么判断connect已经成功呢?
  • 请问linux写socket的客户端如何实现WSAAsyncSelect
  • socket编程,服务器会用bind()绑定端口,而客户端不用绑定端口就可以调用connect()。那么客户端的端口时系统自己分配的么?是何时绑定的?
  • Socket客户端为什么Thread没有效果?
  • socket客户端connect服务端后,如何断开连接?
  • 请教关于socket通讯中客户端接收服务端信息的问题
  • socket 通讯问题!客户端获取服务端数据问题,死活都是0!
  • 关于linux socket 客户端编程
  • 请问,C语言socket编程中,客户端如何得到自己的IP?不要0.0.0.0
  • socket实现多文件并发传输,求助多线程实现问题?
  • 高手啊,请问如何将BufferedImage转换为可以用SOCKET传输的数据
  • linux无线网络传输也可以直接使用socket接口编程吗?
  • 如何用socket一次传输多个文件,如何确定文件一个文件结束
  • linux 下如何图片如何通过socket传输?
  • JB5 Socket传输的汉字如何正常显示???
  • socket传输二进制文件输出是不是要用DataOutputStream?
  • socket(套接字)怎么传输二进制数据?急
  • socket传输
  • (在下等)如何解决socket 传输的丢包问题
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 客户机和服务器可以双向收发数据的socket编程
  • 请问有没有Linux下SOCKET服务端和客户端的接口函数!!
  • aix socket进程为何收到客户端的编码都是ISO-8859-1编码?
  • 怎样使socket对客户端的connect直接拒绝?
  • 请问linux写socket的客户端如何实现WSAAsyncSelect iis7站长之家
  • select+read 读服务器发送过来的数据, 假设服务器调用close后, 客户端的select是否返回这个socket可读?
  • 客户端服务端使用socket通信的send/write最大发送多少?
  • 做最简单的socket客户端,怎么找不到unp.h?
  • SOCKET同时接收客户端连接问题
  • 求FTP客户端源程序(Ansi C, Berkeley Socket)
  • 请教socket通信中的一个小问题,打印客户端的地址会发出警告
  • 问一个socket问题,服务器不停send,客户端进入睡眠服务器会断开
  • 急!socket 客户端数据接收失败
  • VM下的linux Socket程序怎么客户机一连接就出现Bad address的错误?
  • Linux上的客户端异步通知型Socket怎么实现?
  • telnet服务器把标准输出重定向到socket,传递给客户端再输出到屏幕
  • socket客户端问题
  • 客户端 不能发送信息到服务器端?(在SOCKET)请看看下面这段程序有什么错?----客户端的发送信息服务器端收不了!
  • socket传送文件 客户端收到的文件和服务器端发送的不一样?
  • 把socket客户端程序和服务端程序放在同一机器上运行,可以吗?
  • java命名空间java.net类socket的类成员方法: socket定义及介绍
  • re socket编程中 ACCEPT返回的socket与原socket(他参数中的)端口号一样吗?
  • java命名空间java.nio.channels类socketchannel的类成员方法: socket定义及介绍
  • libevent2需要从socket读一段数据写入一个socket中,同时发送给另一个socket
  • java命名空间java.nio.channels类serversocketchannel的类成员方法: socket定义及介绍
  • socket 通讯开发包 Simple Sockets
  • java命名空间java.nio.channels类datagramchannel的类成员方法: socket定义及介绍
  • C++ Socket 库 C++ Sockets
  • java命名空间java.net类socket的类成员方法: getsendbuffersize定义及介绍
  • vc做的的socket应用和unix下socket?
  • java命名空间java.net类socket的类成员方法: getreceivebuffersize定义及介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3