18,356
社区成员
发帖
与我相关
我的任务
分享
BOOL CFTPclient::MoveFile(CString RemoteFile , CString LocalFile , BOOL pasv , BOOL get)
{
CString lhost,temp,rhost;
UINT localsock,serversock,i,j;
CFile datafile;
CSocket sockSrvr;
CAsyncSocket datachannel;
int num,numread,numsent;
const int BUFSIZE=4096;
char cbuf[BUFSIZE];
DWORD lpArgument=0;
// 打开本地文件
if(!datafile.Open(LocalFile,CFile::modeWrite|CFile::modeCreate))
{
return FALSE;
}
if(!FTPcommand("TYPE I")) return FALSE; // 请求二进制传输
// 设置主动的传输模式
//获取本地的ip地址,发送到服务器
if(!m_pCtrlSock->GetSockName(lhost,localsock)) return FALSE;
while(1)
{ // 将IP地址中的点转化成逗号
if((i=lhost.Find("."))==-1) break;
lhost.SetAt(i,',');
}
// 创建数据传输socket并侦听
if((!sockSrvr.Create(0,SOCK_STREAM,NULL))||(!sockSrvr.Listen())) return FALSE;
if(!sockSrvr.GetSockName(temp,localsock)) return FALSE;// get the port that MFC chose
// 将端口转化成2字节,然后加入到本地IP地址中
lhost.Format(lhost+",%d,%d",localsock/256,localsock%256);
if(!FTPcommand("PORT "+lhost)) return FALSE;// 发送端口到服务器
// 发送 RETR 命令到服务器
if(!WriteStr(("RETR ")+RemoteFile)) return FALSE;
if(!ReadStr()||m_fc!=1) return FALSE; // 获得服务器响应
if(!sockSrvr.Accept(datachannel)) return FALSE; // 接收从服务器来的内部绑定数据
/*
// 连接成功,然后进行同步阻塞式数据传输
if( (!datachannel.AsyncSelect(0)) || (!datachannel.IOCtl(FIONBIO,&lpArgument)) )
{
return FALSE;
}
*/
CString str;
while(1)
{
// 开始传输数据
if( !(num=datachannel.Receive(cbuf,BUFSIZE,0)) || num == SOCKET_ERROR )
{
int err = GetLastError();
str.Format("%d\n" , err);
AfxMessageBox(str);
break; // (EOF||network error)
}
else
datafile.Write(cbuf,num); //将数据写入文件
}
datachannel.Close();
datafile.Close();
if(!FTPcommand(""))
return FALSE; // 检查服务返回的响应
return TRUE; // 传输成功
}
if(!(num = datachannel.Receive(cbuf , BUFSIZE)))
break;
else if(num == SOCKET_ERROR)
{
int err = GetLastError();
if(err == WSAEWOULDBLOCK)
{
continue;
}
}
else
datafile.Write(cbuf , num);
那第二个问题呢?