【QT】qt4传文件的实现


前言

本博文主要是对qt4传文件的实现进行的一个介绍,方便后续使用时候可以直接加载,这里需要注意,qt环境为4,而非5

QT4介绍

Qt4是一款跨平台的C++图形用户界面(GUI)开发框架,被广泛应用于软件和应用程序的开发中。Qt4是Qt官方发布的第四代版本,具有许多先进的特性和功能,适用于开发桌面应用程序、嵌入式系统、移动应用和媒体播放器等。

Qt4具有以下特点和优势:

  1. 跨平台:Qt4支持跨多个操作系统和平台,包括Windows、Linux、macOS和嵌入式系统等。

  2. 高度可扩展性:Qt4提供了丰富的类库和工具,使开发人员能够轻松构建复杂的应用程序,并具有很好的可扩展性。

  3. 高效的GUI开发:Qt4采用了一种被称为信号槽机制的事件处理系统,使开发人员能够更轻松地编写和管理GUI代码。

  4. 丰富的UI控件:Qt4提供了大量的预定义UI控件,开发人员可以直接使用这些控件来构建用户界面。

  5. 良好的国际化支持:Qt4支持多国语言和编码的处理,使开发人员能够为全球用户提供本地化的应用程序。

  6. 强大的绘图和图形处理能力:Qt4提供了强大的绘图和图形处理功能,开发人员可以轻松地绘制各种图形、图表和动画效果。

  7. 开源和商业双重许可证: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++要点概要

内敛函数

使用内联函数的时候要注意:

  1. 递归函数不能定义为内联函数。
  2. 内联函数一般适合于不存在 while 和 switch 等复杂的结构且只有 1~5 条语句的小函数上,否则编译系统将该函数视为普通函数。
  3. 内联函数只能先定义后使用, 否则编译系统也会把它认为是普通函数。
  4. 对内联函数不能进行异常的接口声明。

类的大小

类的大小实际是指该类对象的大小。 为类所有非静态数据成员的大小之和, 需要内存对齐。不包括静态数据成员, 不包括函数成员。 但若定义了虚函数, 则需要加上虚指针的大小, 32位机器则+4。 类的大小不能为 0, 由前述规则计算出类大小为 0 时, 实际大小为 1Static 静态数据成员在构造对象的时候, 只会分配 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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

傻傻虎虎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值