2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
1. Http est abbreviatio translationis Protocollum Hypertexta, quae definit speciem communicationis inter navigatores et interretiales ministratores. Simplex postulatio responsionis protocollum est quod super TCP currit solet.
Munus: Certus informationes translationis specificationum inter WWW server et pasco, et est pactum quod utraque pars stare debet.
2.Quomodo http operatur: HTTP fundatur in cliente/servo exemplar et nexus ordinatur. HTTP transaction processus
1. usus QNetworkAccessManager et QNetworkReply classes:
2. Usus QHttpEngine et QHttpNetworkRequest/Responsio classes (inferiore gradu);
Generaliter, ad simplices operationes HTTP, utens summus gradus QNetworkAccessManager instrumenti satis est. Ei commodo commune tractatos necessitatibus mea.
Si potestate inferioris gradus indigere, ut mos HTTP machinae vel rogationis / responsionis singula, uti potes in humili gradu generum quali QHttpEngine.
In summa, Qt praebet exsecutionem clientis HTTP integram, et tincidunt commodiorem interfaciem eligere possunt ad operationes communicationis network secundum actuales necessitates. Hoc bonum subsidium praebet ad applicationes Qt explicandas.
Primum genus: QNetworkAccessManager network iunctio procurator, 2 actiones: impetra/post impetrandi vel petitioni subiciendi, et redde obiectum QNetworkReply quod varias nexus notitias continet.
Secundum genus: QHttpEngine tantum petit nexum administrat nec responsalis ad illas mittendas.
Utere QHttpNetworkRequest ut aedificare rogationem et mitte per QHttpEngine.
Parse QHttpNetworkReply redditum ut responsum acciperet.
- #ifndef MAINWINDOW_H
- #define MAINWINDOW_H
-
- #include <QMainWindow>
-
-
- #include <QtNetwork> // 提供编程TCP/IP客户端和服务器的类
- #include <QUrl> // 提供接口使用URLs
-
-
- QT_BEGIN_NAMESPACE
- namespace Ui { class MainWindow; }
- QT_END_NAMESPACE
-
- class MainWindow : public QMainWindow
- {
- Q_OBJECT
-
- public:
- MainWindow(QWidget *parent = nullptr);
- ~MainWindow();
-
-
- private slots:
- void on_pushButton_clicked();
-
- private:
- Ui::MainWindow *ui;
- QNetworkAccessManager* accesssMgr;
- };
- #endif // MAINWINDOW_H
-
-
- #include "mainwindow.h"
- #include "ui_mainwindow.h"
-
- MainWindow::MainWindow(QWidget *parent)
- : QMainWindow(parent)
- , ui(new Ui::MainWindow)
- {
- ui->setupUi(this);
- accesssMgr =new QNetworkAccessManager(this);
-
- QObject::connect(accesssMgr,QOverload<QNetworkReply*>::of(&QNetworkAccessManager::finished),this,
- [this](QNetworkReply* reply){
- QString read=reply->readAll();
- ui->textBrowser->setText(read);
- reply->deleteLater(); //释放
- });
-
- }
-
- MainWindow::~MainWindow()
- {
- delete ui;
- }
-
-
- void MainWindow::on_pushButton_clicked()
- {
- ui->label->setText("数据正在下载中,请耐心等待......");
- QString url=ui->textEdit->toPlainText();
- qDebug()<<url;
- accesssMgr->get(QNetworkRequest(QUrl(url)));
- }
- #include "httpserver.h"
-
- HttpServer::HttpServer(QObject *parent) : QObject(parent)
- {
- server =new QTcpServer(this);
- //连接回调
- connect(server,&QTcpServer::newConnection,this,&HttpServer::MyselfNewConnectCalllSlot);
- //开始监听
- if(!server->listen(QHostAddress::Any,8088))
- {
- qDebug()<<"n致命错误:Web服务器没有启动,请重新检查!"<<endl;
- }
- else
- {
- qDebug()<<"n正常启动:Web服务器端口:8088,等待客户端连接......"<<endl;;
- }
- }
- void HttpServer::MyselfNewConnectCalllSlot(){
- socket = server->nextPendingConnection(); //获取连接
- while(!(socket->waitForReadyRead(100))); //等待套接字是否有可读数据。 一直阻塞线程等待,直到有可读数据到达套接字,或者超时返回。
-
- QString webdata;
- webdata.resize(1000);
- webdata=socket->read(1000);
-
- qDebug()<<"正常运行:从浏览器读取数据信息......"<<webdata;
-
- //封装http协议
- socket->write("HTTP/1.1 200 OKrn");
- socket->write("Content-Type: text/htmlrn");
- socket->write("Connection: closern");
- socket->write("Refresh: 3rnrn"); // 每秒刷新Web浏览器
- socket->write("<!DOCTYPE>"
- "<html>"
- "<header>"
- "<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>"
- "<title>HttpServer</title>"
- "</header>"
- "<body>客户端已经连接HttpSever服务器秒数为:");
-
- QByteArray byte;
- static qint16 icount=0;
- byte.setNum(icount++);
- socket->write(byte);
- socket->write("</html>");
- /*
- flush() 不会等待数据真正发送出去,只是把数据从本地缓冲区 flush 到内核缓冲区。
- 如果输出缓冲区没有数据,flush() 有可能不做任何操作。
- 调用 flush() 可以确保目前为止写到 socket 的所有数据都发送给对端,而不是 buffered 在本地。
- 一般在发送完请求或应答后调用,保证数据及时发送出去。
- */
- socket->flush(); //刷新 socket 对象的输出缓冲区。 并发送
-
-
- connect(socket, &QTcpSocket::disconnected, socket, &QTcpSocket::deleteLater);
- socket->disconnectFromHost();
- }
http est applicatio tabulatorum protocollo in tcp fundata, sic tcp classes adhibebuntur, et protocollo encapsulation fixa est.Praecipuum membrum munus design
- 请求:
- GET /index.html HTTP/1.1
- Host: www.example.com
- User-Agent: Mozilla/5.0...
- Accept: text/html
-
- 响应:
- HTTP/1.1 200 OK
- Date: Mon, 27 Jan 2020 08:12:31 GMT
- Server: Apache/2.4.1 (Unix)
- Last-Modified: Wed, 22 Jul 2020 19:15:56 GMT
- ETag: "49092-5b6-52c65aa32f280"
- Accept-Ranges: bytes
- Content-Length: 438
- Connection: close
- Content-Type: text/html; charset=UTF-8
-
- <html>
- <head>
- <title>Welcome to example.com!</title>
- </head>
- <body>
- <h1>Hello World!</h1>
- <p>This is the hello world page for an example website.</p>
- </body>
- </html>
-
-
- 这个示例演示了一个简单的HTTP请求和响应过程:
- 客户端发送GET请求获取index.html页面
- 服务器返回200状态码,表示请求成功
- 返回各种报头如日期、服务器信息等
- 返回HTML页面内容作为响应体
Praecipuae classes pro Qt HTTP programmandi sunt QNetworkAccessManager, QNetworkRequest et QNetworkReply.
QNetworkAccessManager:
Administrare nexus et petitiones ad ornatum. Mitte ac data.
Munera provecta praebet ut adepto(), post(), et pone() ut petitiones HTTP incipiant.
Annuit: complevit () authenticationRequired ()
QNetworkRequest:
HTTP repraesentat petitionem. URL et capitis attributa continet.
Petendi modum pone, genus contentus, informationes header, etc.
QNetworkReply:
HTTP responsio repraesentat. Redi status codicem et contentus.
Signis: downloadProgress(), error(), etc. certiorem processui proventus.
Functiones functiones sicut All () legunt responsum contentum.
Principalis gradus:
Facere QNetworkAccessManager rem puta.
Facere obiectum QNetworkRequest ut Domicilium et proprietates instituat.
Munera voca ut QNetworkAccessManager ::adepto() vel post() rogandum.
Audi signa QNetworkReply ut consequitur.
Lege contentum per QNetworkReply, vel errores tractare.
Remove QNetworkReply et petentibus obiecta ne memoria pinum.