在Qt與Http通信的時候,會根據不同的情況使用同步或者異步的方式進行數據請求。
所謂同步,即發送Http請求之后,會一直等待服務器返回的數據,接收到數據之前,程序一直阻塞。
所謂異步,即發送Http請求之后,程序可以繼續往下執行,接收到服務器返回的數據時自動調用其對應的槽函數處理數據。
同步需要在發送請求之后,放置一個QEnentLoop,而異步只需要綁定對應的槽函數即可。
同步代碼如下
QUrl url(myurl); QNetworkReply *reply = quitmanager->get(QNetworkRequest(QUrl(url))); QEventLoop eventLoop; connect(quitmanager, SIGNAL(finished(QNetworkReply*)), &eventLoop, SLOT(quit())); eventLoop.exec(); //block until finish //reply->readall() reply->deleteLater(); reply = nullptr; return true;
異步代碼如下
QNetworkAccessManager *manager = new QNetworkAccessManager; QNetworkRequest *request = new QNetworkRequest;
connect(manager, SIGNAL(finished(QNetworkReply*)), this, SLOT(finishedSlot(QNetworkReply*)));//綁定槽函數
//get post請求二選一 QUrl url(urlHead+"exam_start/"+studentId); request->setUrl(url); manager->get(*request);//發送get請求 QByteArray postData = document.toJson(QJsonDocument::Compact); request->setUrl(url); request->setHeader(QNetworkRequest::ContentTypeHeader,QVariant("application/json")); manager->post(*request, postData);//發送post請求
與請求對應的槽函數,用於處理接收到的數據
void MainWindow::finishedSlot(QNetworkReply *reply) { qDebug() << "進入函數: " << __FUNCTION__; QString json = reply->readAll();//這個返回的JSON包所攜帶的所有信息 QJsonParseError jsonerror; QJsonDocument doc = QJsonDocument::fromJson(json.toUtf8(), &jsonerror); if (!doc.isNull() && jsonerror.error == QJsonParseError::NoError) { QJsonObject object = doc.object(); if(object.contains("type")) { switch (object.value("type").toInt()) { case 1:parseLogJason(object);break; case 2:parseParameterJason(object);break; case 3:parseExamStartJason(object);break; case 4:parseExamEndJason(object);break; default:return; } } } }