今天来把坑填上。 
具体就是提供一个URL,并通过这个URL下载文件。 
MyDownloader.h: 
#ifndef MYDOWNLOADER_H 
#define MYDOWNLOADER_H 
class MyDownloader :public QObject 

Q_OBJECT

public:

//构造函数,要求下载地址,保存位置,进度条(可选)
MyDownloader();
~MyDownloader(); // 设置要下载的url和文件名
void setData(QUrl url, QString pathtoSave);
//开始下载
void getFile();
void startRequest(QUrl url);
//发生的错误代码
int lastError();
//返回是否有错误发生
bool errorValid();
//返回是否下载中
bool isRunning();
//返回是否下载完成
bool isFinished();
//返回所下载文件的版本号
QString getDownloadVersionCode();
//返回所下载文件的名字(带扩展名)
QString getFileName();
void cancel();

private:

//=====状态变量=====
bool bisFinished; //下载是否完成
bool bisRunning; //下载是否进行中
bool bisError; //是否有错误发生
int errorCode; //错误代码
int allBits = 0; //文件大小
bool httpRequestAborted; //=====对象声明=====
QFile *downloadFile; //保存目标文件指针
QUrl downloadUrl; //下载地址Url
QString savePath; //文件存放路径
QString versionCode = ""; //所下载的文件版本号
QString fileName = ""; //所下载文件名
QNetworkReply *downloadReply; //网络应答指针
QNetworkAccessManager downloadmanager; //网络连接主类指针

signals:

//当错误发生时向外抛出错误信息
void error(QNetworkReply::NetworkError);
//抛出下载进度(更新进度条)
void updateProgress(qint64, qint64);
//下载结果 0成功 其他失败
void downloadResult(int retCode);

private slots:

//准备下载,读取数据
void downloadReadyRead();
//下载完成
void downloadFinished();
//下载过程中发生错误
void downloadError(QNetworkReply::NetworkError);
//下载过程进度条
void downloadProgress(qint64, qint64);

};

#endif// MYDOWNLOADER_H

具体实现: 
MyDownloader.cpp:

MyDownloader::MyDownloader() 
{

downloadFile = NULL;
downloadReply = NULL;
bisFinished = false;

}

MyDownloader::~MyDownloader() 
{

cancel();

}

void MyDownloader::setData(QUrl url, QString pathtoSave) 
{

downloadUrl = url;
savePath = pathtoSave;

}

void MyDownloader::getFile() 
{

if (savePath.isEmpty() || downloadUrl.isEmpty())
{
return;
}
if (downloadFile)
{
return;
}
bisFinished = false;
downloadFile = new QFile(savePath); if (!downloadFile->open(QIODevice::WriteOnly))
{
delete downloadFile;
downloadFile = 0;
return;
}
allBits = downloadFile->size();
httpRequestAborted = false;
//尝试获取文件
startRequest(downloadUrl);
//事件循环,防止在下载没完成前结束对象

}

void MyDownloader::startRequest(QUrl url) 
{

QNetworkRequest req(url);
if (allBits)
{
//QByteArray rangeHeaderValue = "bytes=" + QByteArray::number(allBits) + "-";// + QByteArray::number(already + cUpdateChunk() - 1);
//req.setRawHeader("Range", rangeHeaderValue);
//req.setAttribute(QNetworkRequest::HttpPipeliningAllowedAttribute, true);
//req.setRawHeader("RANGE", tr("bytes=%1-").arg(allBits).toUtf8());//
}
downloadReply = downloadmanager.get(req);
//连接信号与槽
if (downloadReply)
{
connect(downloadReply, SIGNAL(readyRead()), this, SLOT(downloadReadyRead()));
connect(downloadReply, SIGNAL(finished()), this, SLOT(downloadFinished()));
//connect(downloadReply, SIGNAL(error(QNetworkReply::NetworkError)), this, SLOT(downloadError(QNetworkReply::NetworkError)));
}

}

QString MyDownloader::getDownloadVersionCode() 
{

return versionCode;

}

QString MyDownloader::getFileName() 
{

return fileName;

}

void MyDownloader::downloadReadyRead() 
{

//如果文件可以访问,下载
if (downloadFile)
downloadFile->write(downloadReply->readAll());

}

void MyDownloader::downloadProgress(qint64 bytesRead, qint64 totalBytes) 

}

void MyDownloader::cancel() 
{

if (downloadFile)
{
downloadFile->close();
delete downloadFile;
downloadFile = NULL;
}
if (downloadReply)
{
downloadReply->deleteLater();
downloadReply = NULL;
}

}

void MyDownloader::downloadFinished() 
{

if (httpRequestAborted)
{
cancel();
return;
}
downloadFile->flush();
downloadFile->close(); QVariant redirectionTarget = downloadReply->attribute(QNetworkRequest::RedirectionTargetAttribute);
if (downloadReply->error())
{//299提示RANGE错误
DEBUG_LOG(qsl("downloadReply error code:") + QString::number(downloadReply->error()));
//downloadFile->remove();
//emit downloadResult(-1);
}
else if (!redirectionTarget.isNull())
{
QUrl newUrl = downloadUrl.resolved(redirectionTarget.toUrl());
{
downloadUrl = newUrl;
downloadReply->deleteLater();
downloadFile->open(QIODevice::WriteOnly);
downloadFile->resize(0); allBits = 0;
startRequest(downloadUrl);
return;
}
}
else
{
QString fileName = QFileInfo(downloadUrl.path()).fileName();
delete downloadFile;
downloadFile = 0;
bisFinished = true;
emit downloadResult(0);
}
downloadReply->deleteLater();
downloadReply = 0;
if (downloadFile)
{
delete downloadFile;
downloadFile = 0;
}

}

void MyDownloader::downloadError(QNetworkReply::NetworkError errorcode) 
{

emit downloadResult(-1);

}

bool MyDownloader::errorValid() 
{

return false;

}

int MyDownloader::lastError() 
{

return 0;

}

bool MyDownloader::isRunning() 
{

return false;

}

bool MyDownloader::isFinished() 
{

return bisFinished;


有些方法没有具体实现,(现在没有用到),是否有错误发生,判断是否下载中,是否下载完成,等 
////////////////////////////////////////////////////////////////////// 
使用: 
mian.cpp 
void main() 
{ 
MyDownloader m_downLoder; 
m_downLoder.setData(QUrl(m_si.custInfo.szLogoLargeUrl.c_str()), bigLogoPath); 
m_downLoder.cancel(); 
m_downLoder.getFile(); 
} 
////////////////////////////////////////////////////////////////////////////////////// 
全文完

http://blog.csdn.net/u011915578/article/details/46592963

QT实现,通过URL下载文件的接口实现的更多相关文章

  1. 从指定的URL下载文件

    通过使用URLDownLoadToFile函数,我们能从指定的URL下载文件,保存到本地,并且下载的文件类型可以是可执行文件 实例如下,http://www.xuexic.com 的根目录下存在一个l ...

  2. 根据URL下载文件

    commons-io 包中已经封装好了,直接可以使用 一.添加依赖 <dependency> <groupId>org.apache.commons</groupId&g ...

  3. wget---从指定的URL下载文件

    wget命令用来从指定的URL下载文件.wget非常稳定,它在带宽很窄的情况下和不稳定网络中有很强的适应性,如果是由于网络的原因下载失败,wget会不断的尝试,直到整个文件下载完毕.如果是服务器打断下 ...

  4. Java从指定URL下载文件并保存到指定目录

    1.基本流程 当我们想要下载网站上的某个资源时,我们会获取一个url,它是服务器定位资源的一个描述,下载的过程有如下几步: (1)客户端发起一个url请求,获取连接对象. (2)服务器解析url,并且 ...

  5. 前端通过url下载文件方法

    前端通过url下载文件方法 产生背景 浏览器通过url下载文件,当浏览器识别出资深能播放的资源文件,就不会走下载流程,会直接打开 解决方法 1.让后台转成请求的方式,输出文件流(如果想实现批量下载-因 ...

  6. HttpClient实现通过url下载文件

    其实就是通过浏览器url,点击就会下载文件. 这里是从代码层面上,对文件进行下载. package main.java.com.abp.util; import org.apache.http.*; ...

  7. 根据文件url,下载文件到本地

    /// <summary> /// 根据文件url,下载文件到本地 /// </summary> /// <param name="fileUrl"& ...

  8. QT:多线程HTTP下载文件

    这里的线程是指下载的通道(和操作系统中的线程不一样),一个线程就是一个文件的下载通道,多线程也就是同时开起好几个下载通道.当服务器提供下载服务时,使用下载者是共享带宽的,在优先级相同的情况下,总服务器 ...

  9. 如何应对POST方式下载文件的接口

    jQuery的下载,需要承载一个插件去做 今天遇到一个问题,后台给的接口由于需要前端传入过多的参数,只能接受用post去下载文件.正常情况下第一反应是用xhr对象去发送post请求,结果并没有触发浏览 ...

随机推荐

  1. rem单位

    rem单位 rem基础 px是固定单位,不同分辨率下效果不一样,导致网页布局出现偏差. em是根据父元素来改变字大小 rem是根据根元素html来改变字体大小,只要改变了根元素的font-size就可 ...

  2. 重构HTML改善web应用设计

    本文从良构,有效性,布局三个角度,结合往日项目开发经历, 整理总结重构HTML改善Web应用设计的几点规则和做法.部分参考自<重构HTML改善Web应用设计>. 重构.什么是重构?为什么要 ...

  3. [转载]VMWare网络连接透析

    http://blog.csdn.net/struggleyb/article/details/1102214 以前在学校,VMWare里面的Gentoo Linux是采用network bridge ...

  4. 浅谈Mybatis(三)

    一.动态SQL 1.sql片段 解决sql语句的冗余代码问题. <sql id="SELECT_T_USER"> select id,name,password,bir ...

  5. 列求key出现的频率

    1 cat mc.log | grep LOGIN_GET | awk '{print $9}' | sort | uniq -c

  6. spoj 10606 Balanced Numbers 数位dp

    题目链接 一个数称为平衡数, 满足他各个数位里面的数, 奇数出现偶数次, 偶数出现奇数次, 求一个范围内的平衡数个数. 用三进制压缩, 一个数没有出现用0表示, 出现奇数次用1表示, 出现偶数次用2表 ...

  7. 共享内存(shared memory)

    共享内存指在多处理器的计算机系统中,可以被不同中央处理器(CPU)访问的大容量内存.由于多个CPU需要快速访问存储器,这样就要对存储器进行缓存(Cache). 任何一个缓存的数据被更新后,由于其他处理 ...

  8. MySQL 关闭子表的外键约束检察

    准备: 定义一个教师表.一个学生表:在学生表中引用教师表ID create table teachers(teacherID int not null auto_increment primary k ...

  9. SMT贴片红胶基本知识

    SMT贴片红胶是一种聚稀化合物,与锡膏不同的是其受热后便固化,其凝固点温度为150℃,这时,红胶开始由膏状体直接变成固体. SMT贴片机装贴贴片具有粘度流动性,温度特性,润湿特性等.根据红胶的这个特性 ...

  10. 三种客户端访问wcf服务端的方法 C#

    原文 http://blog.csdn.net/zlj002/article/details/7914556 string jsonstr = String.Empty; string url = & ...