zoukankan      html  css  js  c++  java
  • 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 }
  • 相关阅读:
    第11条:谨慎地覆盖clone
    第10条:始终要覆盖toString
    第9条:覆盖equals时总是覆盖hashCode
    第8条:覆盖equals时请遵守通用约定
    第7条:避免使用终结方法
    第6条:消除过期的对象引用
    第5条:避免创建不必要的对象
    第4条:通过私有构造器来强化不可实例化能力
    第3条:用私有构造器或者枚举类型强化Singleton属性
    第2条:遇到多个构造器参数时要考虑用构建器
  • 原文地址:https://www.cnblogs.com/wolfplan/p/5937965.html
Copyright © 2011-2022 走看看