EColor бағдарламасын жазу барысында пайдаланушыға бағдарламаның жаңа нұсқасы шыққаны туралы қандай да бір түрде хабарлау қажет болатын тапсырма пайда болды. Бұл мәселенің шешімі сайтта JSON файлының болуы болды. QNetworkAccessManager арқылы біз Qt кітапхана сыныптарының арқасында JSON файлын аламыз және оны талдаймыз: QJsonDocument, QJsonObject, QJsonArray. EColor бағдарламасы жағдайында сайтта бағдарлама аты бар JSON файлы, жолдық нұсқадағы толық нұсқасы және негізгі бөлігі бар үш нысан бар. нұсқа, кіші және патч нұсқасы. Файлды талдау кезінде бағдарламаның ағымдағы нұсқасы сайттағы нұсқасымен салыстырылады. Егер сайтта неғұрлым соңғы нұсқасы орналастырылса, бағдарлама бұл туралы пайдаланушыға хабарлайды.
Мысалы, мекенжай бойынша http://www.evileg.ru/it_example.json сайтта келесі мазмұны бар JSON файлы бар:
{ "departament": "it", "employees": [ {"firstName": "John", "lastName": "Doe"}, {"fisrtName": "Michael", "lastName": "Smith"}, {"firstName": "Anna", "lastName": "Jones"} ], "number" : 3 }
Файлдың түбірлік нысаны үш нысанды қамтиды, олардың екіншісі массив. Бірінші нысан «departament» жолдық қасиеті болып табылады, онда бөлім атауы бар. Екінші нысан - қызметкерлердің аты-жөні бар массив. Ал үшінші объект – Integer типті жұмысшылар саны .
JSON талдауына арналған жоба құрылымы
- JSONParser.pro - жоба профилі;
- main.cpp - жобаның негізгі бастапқы код файлы;
- widget.h - файлды талдау нәтижесі орналастырылатын QTextEdit өрісін қамтитын қолданба терезесінің тақырып файлы;
- widget.cpp - QNetworkAccessManager. бар бастапқы код файлы
- widget.ui - бағдарлама интерфейсінің файлы.
JSONParser.pro
QNetworkAccessManager. сыныбымен жұмыс істеу үшін жоба профиліне желілік модулін қосуды ұмытпаңыз.
#------------------------------------------------- # # Project created by QtCreator 2016-01-02T13:12:55 # #------------------------------------------------- QT += core gui network greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = JSONParser TEMPLATE = app SOURCES += main.cpp\ widget.cpp HEADERS += widget.h FORMS += widget.ui
виджет.h
Біз QNetworkAccessManager класын қосамыз, сонымен қатар SLOT onResult(QNetworkReply *reply) тақырып файлында, онда * JSON файл мазмұнымен сайттан жауап алған кезде талданады * файлы.
#ifndef WIDGET_H #define WIDGET_H #include <QWidget> #include <QNetworkAccessManager> namespace Ui { class Widget; } class Widget : public QWidget { Q_OBJECT public: explicit Widget(QWidget *parent = 0); ~Widget(); private slots: // Обработчик данных полученных от объекта QNetworkAccessManager void onResult(QNetworkReply *reply); private: Ui::Widget *ui; QNetworkAccessManager *networkManager; }; #endif // WIDGET_H
widget.cpp
Процесс QJsonDocument нысанын жасау және оған QNetworkReply. жауабының мазмұнын жазу.Одан кейін құжаттан root түбір объектісін аламыз, оның құрамында барлық үш сипатта болады. Осыдан кейін біз олардың мәндерін қасиеттердің атаулары бойынша аламыз. Екінші «қызметкерлер» қасиетінен бөлім қызметкерлерінің аты-жөні мен тегі бар массив аламыз. Барлық деректер ui->textEdit өрісіне орналастырылады.
#include "widget.h" #include "ui_widget.h" #include <QJsonDocument> #include <QJsonObject> #include <QJsonArray> #include <QUrlQuery> #include <QNetworkReply> #include <QUrl> Widget::Widget(QWidget *parent) : QWidget(parent), ui(new Ui::Widget) { ui->setupUi(this); networkManager = new QNetworkAccessManager(); // Подключаем networkManager к обработчику ответа connect(networkManager, &QNetworkAccessManager::finished, this, &Widget::onResult); // Получаем данные, а именно JSON файл с сайта по определённому url networkManager->get(QNetworkRequest(QUrl("http://www.evileg.ru/it_example.json"))); } Widget::~Widget() { delete ui; } void Widget::onResult(QNetworkReply *reply) { // Если ошибки отсутсвуют if(!reply->error()){ // То создаём объект Json Document, считав в него все данные из ответа QJsonDocument document = QJsonDocument::fromJson(reply->readAll()); // Забираем из документа корневой объект QJsonObject root = document.object(); /* Находим объект "departament", который располагается самым первым в корневом объекте. * С помощью метода keys() получаем список всех объектов и по первому индексу * забираем название объекта, по которому получим его значение * */ ui->textEdit->append(root.keys().at(0) + ": " + root.value(root.keys().at(0)).toString()); // Второе значение пропишем строкой QJsonValue jv = root.value("employees"); // Если значение является массивом, ... if(jv.isArray()){ // ... то забираем массив из данного свойства QJsonArray ja = jv.toArray(); // Перебирая все элементы массива ... for(int i = 0; i < ja.count(); i++){ QJsonObject subtree = ja.at(i).toObject(); // Забираем значения свойств имени и фамилии добавляя их в textEdit ui->textEdit->append(subtree.value("firstName").toString() + " " + subtree.value("lastName").toString()); } } // В конце забираем свойство количества сотрудников отдела и также выводим в textEdit ui->textEdit->append(QString::number(root.value("number").toInt())); } reply->deleteLater(); }
Барлығы
Бұл бағдарлама кодының жұмысының нәтижесінде төмендегі суретте көрсетілген келесі нәтиже алынады. Сондай-ақ, қолданбаның қалай жұмыс істейтінін бейне оқулықтан көруге болады.