MFC通过URL下载并保存文件代码 转载

http://blog.csdn.net/charlessimonyi/article/details/8666108?utm_source=tuicool&utm_medium=referral

 

我们知道,windows有关网络连接的API在wininet.h里,而在MFC里,这些API被封装成了类。

CInternetSession类:直接继承自CObject类,该类用来建立与某个Internet服务器的会话

CInternetConnection类:帮助用户管理与Internet服务器的连接,同时还提供一些函数完成和响应服务器的通信

CInternetConnection类又派生出三个类:

CHttpConnection类:管理与HTTP服务器的连接

CFtpConnection类:用于管理与FTP服务器的连接

CGopherConnection类:管理与Gopher服务器的连接

 

我们要实现根据URL下载并保存文件,就需要CInternetSession、CHttpConnection、CHttpFile。

CHttpFile用来做什么呢?它可以关联起URL指向的一个WEB对象,由于CHttpFile继承与CFile,我们可以像读取一个CFile文件一样,把它从HTTP服务器上下载下来。

MFC就是通过对CHttpFile对象的读写来完成与HTTP服务器的对话的,包括GET/POST提交数据,接收数据。

 

下面就是我自己写的一个根据URL下载并保存文件的函数,注意使用时需要在MFC项目的预编译头文件里加入#include <afxinet.h>,因为上面我提到的那些类全部在这个头文件里。

第一参数为URL,第二个参数为保存路径。

返回值:

0:成功下载保存

-1:URL不正确

-2:建立网络连接失败

-3:向服务器发起GET请求失败

-4:服务器不接受请求

-5:参数一不能为空

-6:参数二不能为空

-7:保存文件时创建或写入文件失败

 1 INT GetFile(const CString strUrl,const CString strSavePath)
 2 {
 3     //检查传入的两个参数
 4     if (strUrl.IsEmpty())
 5         return -5;
 6     if (strSavePath.IsEmpty())
 7         return -6;
 8 
 9     unsigned short nPort;        //用于保存目标HTTP服务端口
10     CString strServer, strObject;    //strServer用于保存服务器地址,strObject用于保存文件对象名称
11     DWORD dwServiceType,dwRet;        //dwServiceType用于保存服务类型,dwRet用于保存提交GET请求返回的状态号
12 
13     //解析URL,获取信息
14     if(!AfxParseURL(strUrl, dwServiceType, strServer, strObject, nPort))
15     {
16         //解析失败,该Url不正确
17         return -1;
18     }
19     //创建网络连接对象,HTTP连接对象指针和用于该连接的HttpFile文件对象指针,注意delete
20     CInternetSession intsess;
21     CHttpFile *pHtFile = NULL;
22     //建立网络连接
23     CHttpConnection *pHtCon = intsess.GetHttpConnection(strServer,nPort);
24     if(pHtCon == NULL)
25     {
26         //建立网络连接失败
27         intsess.Close();
28         return -2;
29     }
30     //发起GET请求
31     pHtFile = pHtCon->OpenRequest(CHttpConnection::HTTP_VERB_GET,strObject);
32     if(pHtFile == NULL)
33     {
34         //发起GET请求失败
35         intsess.Close();
36         delete pHtCon;pHtCon = NULL;
37         return -3;
38     }
39     //提交请求
40     pHtFile->SendRequest();
41     //获取服务器返回的状态号
42     pHtFile->QueryInfoStatusCode(dwRet);
43     if (dwRet != HTTP_STATUS_OK)
44     {
45         //服务器不接受请求
46         intsess.Close();
47         delete pHtCon;pHtCon = NULL;
48         delete pHtFile;pHtFile = NULL;
49         return -4;
50     }
51     //获取文件大小
52     UINT nFileLen = (UINT)pHtFile->GetLength();
53     DWORD dwRead = 1;        //用于标识读了多少,为1是为了进入循环
54     //创建缓冲区
55     CHAR *szBuffer = new CHAR[nFileLen+1];
56     TRY 
57     {
58         //创建文件
59         CFile PicFile(strSavePath,CFile::modeCreate|CFile::modeWrite|CFile::shareExclusive);
60         while(dwRead>0)
61         {  
62             //清空缓冲区
63             memset(szBuffer,0,(size_t)(nFileLen+1));
64             //读取到缓冲区
65             dwRead = pHtFile->Read(szBuffer,nFileLen); 
66             //写入到文件
67             PicFile.Write(szBuffer,dwRead);
68         }
69         //关闭文件
70         PicFile.Close();
71         //释放内存
72         delete []szBuffer;
73         delete pHtFile;
74         delete pHtCon;
75         //关闭网络连接
76         intsess.Close();
77     }
78     CATCH(CFileException,e)
79     {
80         //释放内存
81         delete []szBuffer;
82         delete pHtFile;
83         delete pHtCon;
84         //关闭网络连接
85         intsess.Close();
86         return -7;            //读写文件异常
87     }
88     END_CATCH
89         return 0;
90 }

 

posted @ 2016-10-08 11:37  wolfplan  阅读(2507)  评论(0编辑  收藏  举报