【QT】qt4传文件的实现
前言
本博文主要是对qt4传文件的实现进行的一个介绍,方便后续使用时候可以直接加载,这里需要注意,qt环境为4,而非5。
QT4介绍
Qt4是一款跨平台的C++图形用户界面(GUI)开发框架,被广泛应用于软件和应用程序的开发中。Qt4是Qt官方发布的第四代版本,具有许多先进的特性和功能,适用于开发桌面应用程序、嵌入式系统、移动应用和媒体播放器等。
Qt4具有以下特点和优势:
-
跨平台:Qt4支持跨多个操作系统和平台,包括Windows、Linux、macOS和嵌入式系统等。
-
高度可扩展性:Qt4提供了丰富的类库和工具,使开发人员能够轻松构建复杂的应用程序,并具有很好的可扩展性。
-
高效的GUI开发:Qt4采用了一种被称为信号槽机制的事件处理系统,使开发人员能够更轻松地编写和管理GUI代码。
-
丰富的UI控件:Qt4提供了大量的预定义UI控件,开发人员可以直接使用这些控件来构建用户界面。
-
良好的国际化支持:Qt4支持多国语言和编码的处理,使开发人员能够为全球用户提供本地化的应用程序。
-
强大的绘图和图形处理能力:Qt4提供了强大的绘图和图形处理功能,开发人员可以轻松地绘制各种图形、图表和动画效果。
-
开源和商业双重许可证:Qt4提供了开源和商业双重许可证,开发人员可以根据自己的需求选择合适的许可证。
总之,Qt4是一款功能强大、易于使用和跨平台的GUI开发框架,适用于各种类型的应用程序开发。无论是开发桌面应用程序、移动应用还是嵌入式系统,Qt4都可以提供一套完整的工具和类库来支持开发人员的工作。
功能实现
QT 部分
pro
QT += core gui network
QT += script
.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>
#include <QFile>
#include <QDebug>
#include <QUrl>
#include <QString>
#include <QProgressBar>
#include <QMessageBox>
namespace Ui {
class MainWindow;
}
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = 0);
~MainWindow();
private:
Ui::MainWindow *ui;
QNetworkReply *reply;
QProgressBar *progressBar;
QFile *file;
public slots:
void replyFinished(QNetworkReply*);
void loadError(QNetworkReply::NetworkError);
void loadProgress(qint64 bytesSent,qint64 bytesTotal);
void readContent();
private slots:
void on_pushButton_clicked();
void on_pushButton_2_clicked();
};
#endif // MAINWINDOW_H
.cp
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QDateTime>
#include <QtScript/QtScript>
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
}
MainWindow::~MainWindow()
{
delete ui;
}
void MainWindow::readContent() //下载时向本地文件中写入数据
{
file->write(reply->readAll());
qDebug()<<"jieshoutgfgdg"<<QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz dddd");
}
void MainWindow::replyFinished(QNetworkReply*) //删除指针,更新和关闭文件
{
if(reply->error() == QNetworkReply::NoError)
{
//php返回部分
// QByteArray bytes=reply->readAll();//读取所有字节
// QScriptEngine engine;
// QScriptValue sc=engine.evaluate("value="+bytes);
// qDebug() <<sc.property("result").toString();
// qDebug() <<sc.property("message").toString();//中文会出现乱码,但不影响程序里面的判断
// if(sc.property("message").toString()=="加载成功"){
// qDebug() <<"ni";
// }
// // if(sc.property("chi").isArray()) //解析数组
// // {
// // QScriptValueIterator it(sc.property("chi"));
// // while (it.hasNext())
// // {
// // it.next();
// // if(!it.value().property("a").toString().isEmpty())
// // qDebug() << it.value().property("a").toString();
// // }
// // }
reply->deleteLater();
file->flush();
file->close();
qDebug()<<"jieshoutgsdd"<<QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz dddd");
}
else
{
progressBar->close();
QMessageBox::critical(NULL, tr("Error"), "Failed!!!");
}
}
void MainWindow::loadProgress(qint64 bytesSent, qint64 bytesTotal) //更新进度条
{//16kb一包上发
qDebug() << "loaded" << bytesSent << "of" << bytesTotal;
progressBar->setMaximum(bytesTotal); //最大值
progressBar->setValue(bytesSent); //当前值
}
void MainWindow::loadError(QNetworkReply::NetworkError) //传输中的错误输出
{
qDebug()<<"Error: "<<reply->error();
}
void MainWindow::on_pushButton_clicked()
{
//10.3m--云端测试,948ms
qDebug()<<"jieshoutgs"<<QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz dddd");
file = new QFile("D:/wamp64/www/holeLocking/upload/hello.png");
file->open(QIODevice::ReadOnly);
QByteArray byte_file="";
byte_file=file->readAll();
QNetworkAccessManager *accessManager2 = new QNetworkAccessManager(this); //往该目录中上传文件
accessManager2->setNetworkAccessible(QNetworkAccessManager::Accessible);
QUrl url2("http://ip/holeLocking/upload.php?filename=hsello.png"); //如这里指定的上传文件至HTTP服务器目录中的upload目录中
QNetworkRequest request2(url2);
request2.setHeader(QNetworkRequest::ContentTypeHeader, "application/octet-stream");
reply = accessManager2->post(request2, byte_file);
progressBar = new QProgressBar();
progressBar->setValue(0);
progressBar->show();
connect(accessManager2,SIGNAL(finished(QNetworkReply*)),this,SLOT(replyFinished(QNetworkReply*)));
connect(reply, SIGNAL(error(QNetworkReply::NetworkError)),this,SLOT(loadError(QNetworkReply::NetworkError)));
connect(reply, SIGNAL(uploadProgress(qint64 ,qint64)), this, SLOT(loadProgress(qint64 ,qint64)));
}
void MainWindow::on_pushButton_2_clicked()
{
//10.3m-----云端测试,40s
qDebug()<<"jieshoutgd"<<QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz dddd");
file = new QFile("D:/wamp64/www/holeLocking/upload/1d3d52.doc");
file->open(QIODevice::WriteOnly);
QNetworkAccessManager *accessManager = new QNetworkAccessManager(this);
accessManager->setNetworkAccessible(QNetworkAccessManager::Accessible);
//QUrl url("http://ip/qt/upload/10m.doc");//如这里指定的上传文件至HTTP服务器目录中的upload目录中
QUrl url("http://ip/holeLocking/download.php?filename=23dd.doc"); //采用接口获取
QNetworkRequest request(url);
request.setHeader(QNetworkRequest::ContentTypeHeader, "application/octet-stream");
reply = accessManager->get(request);
progressBar = new QProgressBar();
progressBar->setValue(0);
progressBar->show();
connect((QObject *)reply, SIGNAL(readyRead()), this, SLOT(readContent()));
connect(accessManager, SIGNAL(finished(QNetworkReply*)), this, SLOT(replyFinished(QNetworkReply*)));
connect(reply, SIGNAL(error(QNetworkReply::NetworkError)),this,SLOT(loadError(QNetworkReply::NetworkError)));
connect(reply, SIGNAL(downloadProgress(qint64 ,qint64)), this, SLOT(loadProgress(qint64 ,qint64)));
}
php部分
download.php
<?php
$content = file_get_contents('php://input');
$foldername = "upload";
$filename = $_GET["filename"];
$fp = fopen($foldername."/".$filename,'w+');
fwrite($fp, $content, strlen($content));
fclose($fp);
//使用 FILE_APPEND 标记,可以在文件末尾追加内容
//LOCK_EX 标记可以防止多人同时写入
//($foldername.$filename, $content.trim,FILE_APPEND|LOCK_EX);
// $arr=array("result"=>"true","message"=>"加载成功");
// print(json_encode($arr, JSON_UNESCAPED_UNICODE));
?>
upload.php
<?php
$filename = $_GET["filename"];
//获取文件dir
$file_dir = "upload"."/".$filename;
//打开文件
$handler = fopen($file_dir, 'r+b');
$file_size = filesize($file_dir);
//声明头信息
Header("Content-type: application/octet-stream");
Header("Accept-Ranges: bytes");
Header("Accept-Length: ".$file_size);
Header("Content-Disposition: attachment; filename=" . basename( $file_dir));
// 输出文件内容
echo fread($handler,$file_size);
fclose($handler);
ob_end_flush();
exit;
?>
额外补充
qt4传文件的实现记录就先到这!接下来,是一些整理的c++要点概要!
内敛函数
使用内联函数的时候要注意:
- 递归函数不能定义为内联函数。
- 内联函数一般适合于不存在 while 和 switch 等复杂的结构且只有 1~5 条语句的小函数上,否则编译系统将该函数视为普通函数。
- 内联函数只能先定义后使用, 否则编译系统也会把它认为是普通函数。
- 对内联函数不能进行异常的接口声明。
类的大小
类的大小实际是指该类对象的大小。 为类所有非静态数据成员的大小之和, 需要内存对齐。不包括静态数据成员, 不包括函数成员。 但若定义了虚函数, 则需要加上虚指针的大小, 32位机器则+4。 类的大小不能为 0, 由前述规则计算出类大小为 0 时, 实际大小为 1。 Static 静态数据成员在构造对象的时候, 只会分配 1 个字节。
PAT (*ad)[3]
ad 是数组指针, ad 是个指向有着三个 PAT 元素的数组的指针; 这里只是声明了指针, 虽然指针指向的数组有三个 PAT 对象, 但是没有实例化其中的对象, 所以并没有调用构造函数, 假如改为 pat ad[3],则调用 3 次。
C++11 STL 中的容器
multivector 不是哦
顺序容器
- vector: 可变大小数组;
- deque: 双端队列;
- list: 双向链表;
- forward_list: 单向链表;
- array: 固定大小数组;
- string: 与 vector 相似的容器, 但专门用于保存字符。
关联容器
按关键字有序保存元素: (底层实现为红黑树)
- map: 关联数组; 保存关键字-值对;
- set: 关键字即值, 即只保存关键字的容器;
- multimap: 关键字可重复的 map;
- multiset: 关键字可重复的 set;
无序集合:
- unordered_map: 用哈希函数组织的 map;
- unordered_set: 用哈希函数组织的 set;
- unordered_multimap: 哈希组织的 map; 关键字可以重复出现;
- unordered_multiset: 哈希组织的 set; 关键字可以重复出现。
其他项:
stack、 queue、 valarray、 bitset